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WARRANTY 


All products are warranted against defects in material and workmanship under 
normal and proper use and in their original unmodified condition. If found defective 
by Zendex Corp. within the terms of this warranty, Zendex Corp.’s sole obligation 
shall be to repair or replace at Zendex Corp.'s option the defective product. If 
Zendex Corp. determines that the product is not defective within the terms of this 
warranty, Customer shall pay all costs of handling and return transportation. All 
replaced products become the property of Zendex Corp. As a condition of this 
warranty, customer must obtain a Zendex Corp. Return Material Authorization 
Number, and must return all products, transportation prepaid and insured, to 
Zendex Corp.’s Dublin, CA facility or other specified location. 


Transportation charges for the return to customer shall be paid by Zendex 
Corp. within the contiguous United States only. These warranties outside the 
contiguous United States are limited to repair or replacement only and exclude all 
costs of shipping, customs clearance, and other related charges. Except for the 
express warranties stated above, Zendex Corp. disclaims all warranties on prod- 
ucts, including all implied warranties of merchantability and fitness; and the stated 
express warranties are in lieu of all obligations or liabilities on the part of Zendex 
Corp. for damages, the use or performance with this product. 


Warranty period is one (1) year from date of original shipment. Warranty regis- 
tration card must be returned to Zendex for warranty to be in effect. 


SERVICE POLICY 


If a product should fail during the warranty period, it will be repaired for free. 
There will be a service charge for repair of a product after the warranty period. Ifa 
product exhibits misuse, negligence, or user misconnection, the failure will be 
treated as an out-of-warranty repair. 


To return a product for in-warranty repair, first reverify that the unit is indeed 
at fault. Then, call the factory for Return Material Authorization (RMA) Number. 
The product should be carefully packaged and shipped prepaid using the pro- 
vided RMA number on the outside of the package. Include a short statement of 
the malfunction, along with return address information, and the telephone number 
of a technical contact, in case the need arises. 


For out of warranty repairs, a purchase order for repair charges must also be 
included. 


Items should not be returned freight collect, as they will not be accepted. It is 
absolutely necessary to return products in the manner stated here, otherwise 
considerable delay will result in processing the return. 


OUT OF WARRANTY REPAIRS 


After the warranty has expired, or if no warranty registration is on file, any 
Zendex board product will be repaired or replaced (at Zendex’s option) for a flat 
fee of $100, provided, in Zendex’s opinion, the product has not been abused, 
misused, modified or damaged. Otherwise there will be a time and materials 
charge for returning it to original condition. This policy is subject to cancellation, 
modification, and change without notice. 
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Chapter 1 - General Information 


1.1 Introduction 

The ZX-200A is a single~board floppy disk controller which 
is able to interface from one to four eight-inch single density 
(FM) or double density (MMFM) disks to the multibus structure 
The controller allows up to four single sided drives to be used, 


thus providing up to two megabytes of storage. 


1.2 Description 

The ZX-200A utilizes an 8085A microprocessor and 8257 DMA 
controller to perform all disk controller functions. Single or 
Gouble density operation is under software control, and full 
emulation of standard Intel disk systems is possible. The ZX-200A 
can fully replace the Intel disk controller boards used in the 
MDS-800 and MDS 220/230 Development Systems, and can operate under 


ISIS-II software. The ZX-200A uses one Multibus card slot. 


Figure 1 - Z2xX-200A 


Zendex Corporation has been licensed by Micromation Cor- 
poration to build the ZX-200A using the Micromation MM-SBC-80F 
Multibus Floppy Disk Controller printed circuit artwork. Thus the 
layout, configuration, and features of the ZX-200A match the MM- 
SBC-80F. The Micromation manufactured board sold by Zendex was 


known as Model ZX-200 


1.3 Equipment Supplied 
The following equipment is supplied with the ZX-200A: 


ZX-200A Hardware Reference Manual; with 
Schematic Diagram D200-O1A; and 
Assembly Diagram 


1.4 Compatible Equipment 
CPU: The ZX-200A is compatible with any CPU, which is 


multibus compatible and is capable of multimaster operation, such 
as; 

ZX-85, 88, 86 

SBC-86/12A 

ZX-80/05 


Disk Drive: The ZX-200A is compatible with the following 
drives or their equivalents: 
- Shugart Associates 800/801 
Memorex 550/552 
CDC 9404 
Host Software: The ZX-200A is compatible with the following 
software: ISIS-II (Intel) 
CP/M for MDS 
Intel FORTRAN, BASIC 
UCSD PASCAL for CP/M 
Intel PLM, RMS-80 (Host) 
Emulation: The ZX-200A emulates and can replace the 
following Intel disk controllers: 


Single Density - SBC-201, SBC-211, SBC-212, MDS-2DS, MDS-710 
Double Density - SBC-202, MDS-DDS, MDS-720 


The ZX-200A when sold in combination with the Zendex ZX-730 


Dual Drive Unit, is known aS ZX-710/720 Mod 200A. 


1.5 Specifications 


Table 1 


ZX-200 Specifications 


Single Density (FM) Ports 88H-8FH 


Operation Modes 
Double Density (MMFM) Ports 78H-7FH 


Compatible with MULTIBUS specifications 
See Intel publication 9800083-02 


System Bus 
Interface 


Accommodates Shugart 800 Series standard 


Floppy Disk 
size disk drive (8 inch) 


Dive Interface 


Power Requirement +5 volts at 2.75A (TYP) 


0 degrees to 40 degrees Centigrade 
Humidity 0 to 90 percent RH non-condensing 


Dimensions 12 inches long 
6.75 inches wide 
0.50 inches deep (one card slot) 
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Chapter 2 - Preparation for Use 


2.1 Introduction 
This chapter provides information on preparing and instal- 
ling the ZX-200A, Included are instructions on unpacking and 


inspection as well as information on installation procedure. 


2.2 Unpacking and Inspection 

Inspect the shipping carton immediately upon receipt for 
evidence of mishandling during transit. If the shipping carton is 
severely damaged or waterstained, request that the carrier's agent 
be present when the carton is opened. If the carrier's agent is 
not present, and the contents of the carton are damaged, keep the 
carton and packing material for the agent's inspection. | 

For repair to a product damaged in shipment, contact Zendex, 
Inc. to obtain further instructions. A purchase order will be 
required to complete the repair. A copy of the purchase order 
should be submitted to the carrier with your claim. 

It is suggested that salvageable shipping cartons and pack- 
ing material be saved for future use in the event the product must 


be shipped. 


Please fill out warranty card immediately and return to 
zendex. This is your only way to receive regular ECO information 


and various updates that may become available. 


2.3 Installation Considerations 

The ZX-200A is intended to replace the two-board Intel 
Diskette Controller set (Channel and interface boards). It should 
be inserted into the card slot that would have held the Intel 
Diskette Interface Board. In order to ensure that the ZX-200A 
connects properly to the bus resolving multibus signals (BPRN/, 
BPRO/, BREQ/), it must occupy an odd-numbered card slot in the 
MDS~800 only. Series II and III can be in any slot. 

The user should be aware of the fact that the Intellec MDS 
220 has a single density drive mounted in the cabinet ext to the 
CRT. This drive is controlled by the IO controller board, which 
is located not in the card cage, but at the back of the cabinet. 
The ZX-200A can still be plugged into the card cage, however, the 
Original integrated single drive (ISD) will respond as :F4: under 
ISIS-II, rather than physical drive zero; and physical drive one 
will also respond as single density drive :F5:. 

Before installing the ZX-200A, turn off all system power and 
remove the front panel (MDS 220/230), or the top panel (MDS 800). 
If the Intel channel and interface boards are installed, first 
remove the cable from the interface board, then remove both 
boards. Allow the ZX-200A to run both the eingie and double 
density systems. The Intel disk controller must be removed. 

Before installing the ZX-200A, clean off the multibus and 
disk drive cable edge connector fingers with alcohol and for MDS- 
800 plug the 2ZX-200A controller into an odd-numbered slot of the 


card cage. 


If the ZX-200A has been purchased in conjunction with a Z2X- 
710/720 MOD 200 System, all cabling necessary to connect the 2X- 
200A to the ZX-730 disk drives is supplied. If the ZX-200A is 
purchased separately, a fifty-pin ribbon cable must be made. This 
must have a fifty-pin printed circuit connector in place at each 
end. This can connect the ZX-200A edge connector directly to four 
disk drives. The ZX-200A connector is pin for pin compatible with 
Shugart SA800. The cable supplied with the Intellec MDS is of no 
use and may be set aside. 

Refer to Figure 2, for the jumper options required of a 


Shugart SA80IR for use with the ZX-200A. 
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Figure 2 - Jumper Adaptions for ZX-200A 


2.4 Jumper/Trace Cut Options 
Various jumper and trace cut options are offered to allow 
maximum flexibility when working with the ZX-200A. These are 


arranged as follows: 
Factory 
Label Function Default Location 


Wl, W2 Drive Assignment Select Wl in Near U12 
These two jumpers allow W2 in 
four possible choices 
with respect to the 
various drive name and 
density assignments un- 
der CP/M or ISIS. How- 
ever, the present firm- 
ware does not make use 
of these jumper posi- 
tions; therefore, the 
user may configure 
these jumpers as desir- * 
ed and allow the soft- 
ware to read their 
States and branch ac- 

| cordingly. Remember, 
the current firmware 
does not use these 
jumpers. 


Reserved for future Near U43 
use 


Head Load Near Ull 


Disk Drive Buffer En- 
able. This jumper al- 
lows the disk drive 
buffer to be either 
enabled permanently or 
to be enabled by the 
head load signal. Nor- 
mally, the buffer 
should be enabled by 
the head load signal in 
order to qualify the 
disk control signals 
and avoid glitches on 
the drive select lines. 


(A-B-C) 


Jumpers (continued) 


Label 
TV 


A-B, 


C-D 


Daisy Chain Priority 
Resolution. The ZX-200A 
Can operate either with 
daisy chain or parallel 
resolution. To select 
daisy chain resolution, 
install a jumper plug 
from T to V. For paral- 
lel resolution, leave 
the jumper plug out. 


System Interrupt. 

G and H plated through 
holes are the outputs 
from the interrupt gen- 
erator circuitry. A 
jumper is installed at 
the factory from G and 
H, to N (INT2/). This 
is the standard config- 
uration. G represents 
an interrupt associated 
with addresses 88H to 
8FH, while H represents 
the same from 78H to 
7FH. 


Disable Controller for 
78H or S88H*. There 
are four plated through 
holes in the PCB next 
to the U43. Each pair 
of holes is connected 
with a trace on the co- 
ponent side when ship- 
ped from the factory. 
Cut the trace between 


the hole pair closest. 


to U43 and the ZX-200A 
will not respond to 
addresses 78H to 7FH 
(usually, but not al- 
ways for double den- 
sity). Cut the other 
trace and the ZX-200A 
will not respondto 
addresses 88H to 8FH 
(always single density) 


Factory 
Function Default 


Installed 
G-H-N 
U71-U73 


AB Connector 


CD Connector 


Location 


Near U67 


Near U43 
on 
component 
side 


Trace Cut (continued) 


Label 


Write 
Enable 


Factory 
Function Default 


Write Protect. There Connected 
are two plated through 
holes between U12 and 
U13 which are connected 
by a_ trace on the 
solder side. If the 
trace is cut, the con- 
troller will not write 
to any of the disk 
drives connected to it. 


Advance Acknowledge G-H 
There are three plated connected 
through holes between H-J open 
U6é9 and U70. The one 

Closest to the 86-pin 

connector goes to the 

/AACK backplane signal 

and nowhere else. The 

other two holes are 

connected by a trace on 

the solder side and are 

connected to the /XACK 

backplane signal. Nor- 

mally, the /XACK signal 

is the one that should 

be used, since the 

/AACK signal is being 
abandoned by various 
Multibus standards. 

However, should the 

user wish to use /AACK, 

cut the trace on the 

solder side and connect 

a jumper between the 

middle hole and the 

one closest to the 86- 

pin connector. 


* Note: In order to have the ZX-200A respond to 
addresses other than 78H to 7FH or 88H to 8FH, 
U43, the I/O MAP PROM, MAP23 at U43, must be 
changed by the user as desired. Zendex does not 
offer or support alternate PROMs. It should be 
kept in mind before changing PROMs that the fac- 
tory PROM is compatible with CP/M and ISIS-II 
requirements. 
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Location 


Between 
ULZ, Ul3 


Between 
U69, U70 


Chapter 3 - Operating System 


The ZX-200A will run under either the CP/M or ISIS-II opera- 
ting systems. An important fact, which needs clarification at 
this point is how the disk drives are numbered according to 
recording density and operating system. Table 3-1 shows how the 


drive numbers are assigned. 


Physical Single Double 
i i Density . Density 


Table 3.1 Drive Number Assignments 


In order to bring up the operating system for a particular 
configuration, the double density system disk must be placed in 
Drive zero. 

In a two drive Zendex or Intel double-density system, drive 
zero is on the right, drive one is on the left, and for the 
Single density system, drive four is on the right, drive five is 


on the left. However, the situation becomes more complicated than 


| 


this, because a total of five drives could be utilized in an MDS- 
220 system, where the drive next to the CRT is controlled by the 
I/O controller in the MDS-220 chassis, and up to four external 
drives may be controlled by the ZX-200A. _ 

The main thing to remember is that the logical number of a 
physical drive depends on the density of the diskette inserted in 
it at the time. 

If a drive has a single-density diskette inserted in it, the 
only possible logical numbers for that drive are either :F4: (Cs) 
Or :F5: (D:). If it has a double-density inserted in it, the only 
possible numbers for that drive are: :FO:(A:), sFls(B:), s:F2:, 
7F3:. An attempt will be made to illustrate various drive number 
assignments for MDS-800, MDS-220 and MDS-230 Systems as a function 
of number of drives, density of diskette inserted. See the table 


on the following page. 


L2 


Table 3.2 


Drive Assignments for MDS-800, MDS-220 


Drive Assignment Diskette 


ee oes 


MDS-800/ 
MDS- 230 


MDS-800 Two-drive System 


MDS-800/ 
MDS-230 


MDS-800 Four-drive System 


MDS~-220 


MDS-220 Five-drive System 


MDS-220 


MDS-220 Three-drive System 


*Single-density drive #4 always located in CRT chassis 


The above illustration assumes that the ZX-200A is the only 
disk controller in the system aside from the IOC inside the MDS- 
Series II or III. The maximum number of drives in this case is 
five; four controlled by the ZX-200A and one controlled by the 
MDS-220 IOC. 

CAUTION: If the CP/M is used with the MDS-220, 

and the MDS-220 is controlling two external 

drives,the MDS-220 drive is always single density 

and with ISIS is drive four. However, with CP/M 


this drive is invisible to the operating system 
and is not accessable. 


bE 


Once the system configuration is well understood, all cab- 
ling is in place and the ZX-200A jumpers and trace cuts are under- 
stood and implemented, the operating system may be loaded. MThis 
is done according to the type of system being used, as follows: 

MDS-220/230 (All Series II or III) 

(1) Apply power to the MDS-220/230 and to the 

floppy disk drives. A prompt will appear on the 

CRT indicating that the system monitor has Been 

entered. 

(2) Insert the double density ISIS or CP/M sys- 

tem disk in Drive zero with the label facing up or 

left depending on horizontal or vertical drive 

mounting, and close the door. 

(3) Press the system RESET button. A disk access 

will take place, the operating system gets loaded, 


and the sign-on message and prompt are displayed. 


MDS-800 and Zendex Models 835, 838 

(1) Turn the power on/off key to the on position. 
Apply power to the drives. 

(2) Insert the double density ISIS or CP/M system 
disk in drive zero with the label facing up or 
left depending on horizontal or vertical drive 
mounting, and close the door. | 

(3) Depress the top of the BOOT push button on the 


MDS-800 panel. This enables the bootstrap PROM. 
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(4) Press the top of the RESET push button. A 
disk access will take place and the Interrupt two 
light on MDS-800 will be illuminated. 

(5) After the Interrupt two light turns on, hit 
the space bar of the system terminal device. The 
Interrupt two light turns off. A Zendex system 
will sign on at this point. 

(6) Press the bottom of the BOOT push button to 
disable the bootstrap PROM. The operating system 
is loaded from disk, and the sign-on message and 


prompt are displayed. 
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Chapter 4 - Programming Information 


4.1 Introduction 

| The ZX-200A operates in an Intel Intellec MDS environment 
and responds to CPU commands issued over the multibus. The Z2X- 
200A therefore, conforms to the software protocol of the Intel 
controller boards that it replaces. 
4.2 Operational Modes 

The ZX-200A operates in two modes: 

(1) When it hasn't been selected to perform a disk related 
function, it is in the IDLE MODE. In this mode, it is constantly 
looping through a routine that checks the status of the disk 
drives. If a change in the status is noticed (a disk is removed 
Or inserted, for instance), an interrupt is sent to the CPU to 
register the change. 

(2) During program execution, The ZX-200A is selected 

- to perform diskette reads and writes 
- to be reset | 


- to stop prematurely a group of linked disk 
operations (in single density operation only) 


- to render diskette drive status to the CPU 


- to indicate the result of an operation to 
the CPU 


Each of the above operations is initiated by a CPU input or 
output to a specific port. There are two base addresses, one for 


single density operation and one for double density. (Although 
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the ZX-200A reads or writes in both densities, Intel has separate 
floppy disk controllers for each density.) 
The base address for single density operation is at 88H and 


the base address for double density operation is 78H. 


4.3 I/O Parameter Block (IOPB) 

The IOPB consists of ten (in single density Operation) or 
seven (in double density operation) bytes of information which 
indicate the disk operation to be performed. The former has more 
bytes per IOPB because the original Intel single density control- 
ler permitted the linking of several IOPBs together. Several bits 
(see the description of the channel word) and bytes are present to 
accommodate this feature. The Intel double density controller 
does not include the linking feature. 

The ten IOPB bytes are described on the following page. 
In the description, the first seven commands apply to both single 
and double density operation. The last three are used in single 


density only. 
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The IOPB is stored in main memory and thus is accessible by 
both the ZX-200A and the CPU. | 
The ten* IOPB bytes are: 
Byte 1: Channel Word 
Byte 2: Diskette Instruction 
Byte 3: Number of Records 
Byte 4: Track Address 
Byte 5: Sector Address 
Byte 6: Buffer Address (lower) 
Byte 7: Buffer Address (upper) 
* Byte 8: Block Number 
* Byte 9: Next IOPB Address (lower) 


* Byte 10: Next IOPB Address (upper) 


The host CPU must write the IOPB to main memory. Once 
written, the host CPU instructs the ZX-200A as to the IOPB 
locations through I/O ports. These instructions are called chan- 


nel commands and are explained later. 


* Single density operations only. 


IOPB Byte 1 - Channel Word 


Figure 4.1 


Channel Word 


7 6 § 4 3 2 jij J 


(LSB) 


Wait 

Branch on Wait 

- Successor Bit 
Data Word Length 


Lock Override 
Random Format Sequence 
Interrupt Control 
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Bit 0, 1 - Wait, Branch on Wait 


Action 


RR OE rer pee te rene peRE TOT ERIE REE 


Immediately perform the current IOPB. 


Idle for ten MS after which the Wait bit 
(bit 0) is examined. This loop is exe- 
cuted until the wait bit is reset. 


Illegal 


An unconditional jump to the 16-bit ad- 
dress pointed to by bytes nine and 
ten of the IOPB. The next IOPB to be 
performed must be resident at this 
address. 


Double Density Mode (Port 78) 

Bits zero and one are not used in the double density mode, 
since linked IOPBs are not supported in the double density mode. 
The ZX-200A Controller, therefore, will not wait and will execute 


only the correct IOPB. 


Bit 2 - Sucessor 

Single Density Mode (Port 88) 

The sucessor bit (Bit 2) is reset if the current IOPB is the 
last (or only) one to be executed. Setting this bit indicates 
that a succesor IOPB is to be executed; its address is in IOPB 
bytes nine and ten. The diskette controller will issue an inter- 
rupt when the operation is complete, bit two is reset, and bits 
four and five of this byte allow interrupt. 

Double Density Mode (Port 78H) 

Bit two is not used in the double density mode, since linked 


IOPBs are not supported. 
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Bit 3 — Data Word Length 
Bit three must always be reset to a zero, to specify eight 
bit word length, since 16-bit word lengths are not allowed on the 


ZX-200A. 


Bit 4, 5 - Interrupt Control 


Generates interrupt: (a) upon completion 
of an unchained diskette operation; (b) 
after the last operation in a chain of 
linked operations; or (c) upon detection 
of an error in any intermediate 
Operation in a chain of linked 
Operations. 


1 Disable disk operation complete inter- 
rupt to CPU. 
1 1 


Generates disk operation complete inter- 
rupt to CPU after current operation even 
though it is not the last in a chain of 
linked IOPBs. This code is illegal in 
the double density mode. 


Bit 6 — Random Format Sequence 

A logical zero in this bit assigns sequential sector addres- 
ses when a disk is formatted. A logical one writes the sector 
addreses according to a pattern listed in a 52 byte memory buffer 
pointed to by bytes six and seven of the IOPB (see below). 

Bit 7 -— Lock Override 

Single Density Mode (Port 88H) 

When set (logical one), this bit prevents the "wait" bit 
from being set upon completion of the current operation specified 
in the IOPB. When reset (logical zero), this bit alows the ZxX- 


200A to set the "wait" bit. 
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Double Density Mode (Port 78H) 


This bit is never used in the double density mode, since the 


ZX-200A never sets the "wait" bit in double density. 


The following figure summarizes byte one of the IOPB, the 


channel word. 


Figure 4.2 


Summary of Byte One of the IOPB 


Single Density Mode (Port 88) 


7 6 5 4 3 2 1 «0 


Lock Override —— 
Random Format Sequence ‘ 
Interrupt Control 


Data Word Length 


Wait 
Branch on Wait 
- Successor Bit 


Double Density Mode (Port 78) 


6 5 4 3 


i. Data Word Length 


Interrupt Control 


Random Format Sequence 


Must be zero 
Doesn't care 


i) 
i 


Figure 4.2 


Byte Two - Diskette Instruction 


7 6@ 3S 43 21 90 


fotof* | jit | ase) 


Reserved Ae. | Code 
Unit Select 


Data Word Length 


21 


Table 4.1 Op Code 


Bits 0, 1, 2 — OP Code 


epee 
Vie emcee 


1 Seek: move the head to the track indicated in 
byte four of the IOPB. 


Format track: write the address marks, gaps ad- 
dress fields and data fields on the track indi- 
cated in byte four of the IOPB. This type of 
format is determined by bit six of byte one as 
described below. . 


Read datas transfer N sectors (N' indicated by 
byte three of the IOPB) from the disk to system 
RAM. The destination locations in memory start 
at the address pointed to by bytes six and seven 
of the IOPB. If the head is not already 
positioned over the track indicated by byte four 
of the IOPB, it is moved automatically. A CRC 
check is performed,which compares the two bytes 
of CRC written on the disk with the two gener- 
ated from the data address mark and data field 


Verify CRC: check the CRC of the indicated 
sector(s). The operation is similiar to a READ; 
however, no data is transferred to memory. 


Write Data: write N sectors (N specified in byte 
three of the IOPB) from the contents of memory 
that starts at the location indicated in IOPB 
bytes six and seven. As in read, the head is 
automatically moved to the desired track (from 
byte four of the IOPB) if it is not already 
there. Two bytes of CRC are generated and 
written to the disk. Note that multi-sector 
writes (N greater than 1) may not extend beyond 
a Single track. 


Write "Deleted" Data: write N sectors as 
described in the preceding operation except write 
a "deleted data mark" rather than the "normal" 
data mark. 


Riis 
iE 
es 
L 
fe 
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Bit 3 -— Data Word Length 


Bit three must always be reset to a zero to specify eight- 


bit word length, since the 2ZX-200A will not 


Bits 4, 5 - Unit Select 


handle 16-bit words. 


Single Density Mode (Port 88H) 


| 0 0 | prive 0 


Double Density Mode (Port 78H) 


Table 4.2 -— Unit Select, Bits 


Bits 6, 7 - Reserved 
These bits are not used and should 
times. 


IOPB Byte 3 —- Number of Records 


4 and 5 


be set to zero at all 


Byte 3 indicates the number of records (sectors) to be 


written/read. The number must be written in binary and may not 


exceed 26 in single density operation or 52 in double density 


Operation. (Recall from the description 


of the Op Code above, 


that a read write operation may not extend beyond a single track.) 


ao 


IOPB Byte 4 - Track Address 

A binary code in byte 4 indicates the desired track number. 
Acceptable values are 00 to 4C hex (0 to 76). 

IOPB Byte 5 —- Sector Address 

This byte specifies the first (or only) sector for opera- 
tion. In single density mode specify 1-1A,qg (26,9) and in double 


density mode 1-341¢ (529). Bit five of this word must equal bit 


five of byte two in single density mode only. 

IOPB Bytes 6, 7 - Buffer Address 

These bytes specify the address of the disk buffer block for 
Read/Write/Format operations. Byte six is the least significant 
eight bits of the address while byte seven is the most significant 
portion. 

Note: The next three IOPB Bytes (8, 9, 10) are 

used for single density applications only. They 

are used when a chain of IOPBs is to be executed. 

Note that this feature is not used frequently. 

(In fact, Intel dropped this feature from its 

double density controller.) If chaining is not 


used, these three bytes have no effect. 


IOPB Byte 8 - Block Number (Single Density Only) 

The specific number of the current IOPB is specified in this 
byte. Only six bits (5-0) are used. The block number allows the 
CPU to associate an I/O complete interrupt request from an inter- 
mediate link in a chain of IOPBs with the IOPB which actually 
caused the interrupt. The block number need only be initialized 


for linked IOPBs, since there can be no uncertainty when only a 
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Single IOPB exists. This byte and bytes nine and ten are used for 


linked IOPBs. 


IOPB Byte 9 - Next IOPB (Lower Address) 
(Single Density Only) 


The least significant byte of the 16-bit memory address of 
the next IOPB is entered in this byte. 


IOPB Byte 10 — Next IOPB (Upper Address) 
(Single Density Only) 


The most significant byte of the 16-bit memory address of 
the next IOPB is entered in this byte. If the successor bit itwo) 
of IOPB byte one is set (logical 1), the controller accesses the 
IOPB starting at this address upon completion of the current 
Operation. If the successor bit is zero, it is assumed that the 
Current IOPB is the last. The controller also looks at the 


"branch on wait" and "wait" bits in IOPB byte one. If both are 


set (logical 1), a. jump to the IOPB at the address identified here 


is performed. 


4.4 Disk Commands 

The ZX-200A is capable of performing seven distinct opera- 
tions: Recalibrate, Read, Write, Write Deleted Data, Record, 
Verify CRC, Seek, and Format. To begin any operation, the host 
CPU should output both bytes of the 16-bit memory address that 
point to byte one of the IOPB. The operation to be performed is 
specified in byte two of the IOPB. After the ZX-200A receives the 
upper byte of the IOPB address, it accesses the IOPB to interpret 
the operation to be performed and acquire the various parameters 


necessary to carry out the execution. The ZX-200A will set the 
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interrupt flip-flop after it has oeurornea the operation or has 
halted operation due to errors. 

The eight diskette operations are explained in more detail 
in the following paragraphs. 

| Recalibrate (Opcode 3 of IOPB Byte 2) 

This operation will cause the selected unit's head to move 
Over Track zero. Operation is mechanically verified by detectors 
in the drive itself. 

Seek (Opcode 1 of IOPB Byte 2) 

This operation will cause the selected drive to position its 
head over the specified track. Seek Track zero is tested for 
and, if issued, Recalibrate is executed instead. 

Read (Opcode 4 of IOPB Byte 2) 

This operation will return the specified number of data 
records to be written to the buffer, beginning at the given buffer 
address and continuing ipwerd, starting with the track and sector 
given in the IOPB. 

Write Data (Opcode 6 of IOPB Byte 2) 

This operation is the same as Write Data except that each 
128 byte data field is preceded with a deleted data address mark. 

Verify CRC (Opcode 5 of IOPB Byte 2) 

This ppavabinn will read the data records to verify the CRC 
check word. No data is transferred to ene buffer. 

Format a Track (Opcode 2 of IOPB Byte 2) 

This operation is used to initialize a new disk or restorea 
"wiped-out" track. Prior track contents will be lost. 

It should be noted here that a track can be "wiped-out" if 


the operator shuts off power to the diskette system while the 
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diskette is installed or the reset is hit while heads are loaded. 
Pop out diskettes BEFORE power-down or reset! 

The order sector numbers that are assigned in the formatting 
of a track will depend on the state of the "Random Format" bit in 
byte one of the IOPB. If the random format bit is set, the 
pattern of sector addressing and initial sector data contents wiil 
be prescribed by the information in the buffer. 

For Random Format the buffer contains the sector numbering, 
in order of assignment on the track, beginning with the first byte 
of the buffer and continuing through each odd numbered byte. The 
even numbered byte (one greater than sector address) will be the 
data to be initially written to all 128 bytes of the sector. 


For example, if the buffer was constructed as: 


the first physical sector of the track will be numbered seven with 
20 as data in each of its 128 bytes. The second physical sector 
will be numbered five with all ones as initial data. 

If the Random Format bit is reset, the order of sector 
numbering will be that of the physical sector and the initial data 
written to all sectors will be that of byte one of the buffer. 

No Operation (Opcode 0 of IOPB Byte 2) 

The No-Op instruction causes the ZX-200A to execute a read 
drive status and is intended to verify that the controller is 


functioning. 
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4.5 Channel Commands 

Diskette status, result, and IOPB information are communi- 
cated over a set of I/O channels and are called, as a group, the 
Channel Command. 

Once a proper IOPB has been constructed in main memory the 
controller must be informed of the IOPB address via Channel Com- 
mands. Upon completion, or interrupt, result data is available 
with error indications by way of Channel Commands. 

When the Write IOPB Address Upper is executed the disk 
system will commence the operation specified in the IOPB. There- 
fore, the lower portion of address and the entire IOPB must have 
been properly constructed before this Channel Command is executed. 

Out Port 7F 8F - Reset 

This output channel command causes all logic in the ZX-200A 
to be reset to an initialized state. This command is intended to 
Clear hang-ups. 

Out Port 79 89 - Write IOPB Address Lower 

This channel command outputs the low byte of the 16-bit 
address pointing to byte one in the IOPB. 

Out Port 7A 8A - Write IOPB Address Upper 

This channel command outputs the high byte of the IOPB's 16- 
bit address. This command also causes the ZX-200A to begin exe- 


cution of the IOPB. 
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Out Port 8B - Stop 

The diskette controller will stop operation AFTER completing 
the current IOPB instruction. It will not proceed to the next 
IOPB in alink. This channel command has no meaning in double 


density mode since linked operations are not performed. 


In Port 78 88 —- Status Input 
This input channel command causes the ZX-200A to return the 


drive and controller ready status. 


Table 4.3 - Status Word 


Bit 0 Ready Status of Drive 0 

Bit l Ready Status of Drive l 

Bit 2 Interrupt Pending 

Bit 3 Controller Present 

*Bit 4 Double Density Controller Present 
*Bit 5 Ready Status of Drive 2 

*Bit 6. Ready Status of Drive 3 

Bit 7 


Hard Disk Present 
*Active in Port 78 only (double density mode) 
Bits zero, one, five and six, allow the host to determine 


whether the target drive is ready (bit equals one) or not (bit 


equals zero). 
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In Port 79 89 - Read Result Type 
This input channel command will return a two bit result type 
(bits 0 and 1) and, for 201 mode only, a block number in bits two 


through seven. The result type is decoded as: 


Meaning 


I/O complete. Result byte contains error 


bits. 


1 Single Density mode only. I/O complete, 
result byte contains linked error bits. 

fe ae hae Result byte has drive ready status. 
ee 


Table 4.4 Read Result Type 


The Result Type command must be issued to clear the system 
interrupt and diskette controller interrupt pending bits (which 
toggle together) in the status word. 

In Port 7B 8B —- Read Result Byte 

The channel command causes the ZX-200A to return eight bits 
of operation results. The proper interpretation of the result 


byte depends upon the result type. For result types 00 and 01: 


o GPP brhl 


Not Ready 

Write Error 

Write protect 

Data Overrun/underrun 
Address Error 

Seek Error 

CRC Error 

Deleted Record 


Figure 4.5 


Port 7B-8B Read Result Byte for Result Types 00 and 01 
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If the host executes a ‘read result byte' channel command, 
the diskette channel will return the result word on the system 
data bus. The bits are defined as follows: 

Not Ready: 

Bit seven indicates the selected unit was not ready orc the 
selected unit changed to a not ready status during operation. 

Write Errors: 

Bit six indicates that during a write operation a condition 
existed which precluded data integrity. An example of a condition 
causing this error is an attempt to write a 'not ready FDD.' 

Write Protects: 

Bit five indicates the selected drive contains a diskette, 
which is not write enabled. This condition is checked on format a 
track, write data (with data address marks) and write data (with 
deleted data address marks) operations. | 

Data Overrun/Underrun Error: 

Bit four indicates that the ZX-200A controller was not able 
to service a byte transfer request from the drive before the next 
request occurred. The data byte is lost. 

Address Error: 
Bit three indicates that the disk address received from the 


CPU is invalid; that is: 


track address > 7649 


sector address = 00 


- sector address > 52,9 (202 mode) 


- sector address > 2619 + number of records >52 19 (202 mode) 


- sector address + number of records > 2610 (201 mode) 
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Seek Error: 

Bit two indicates that at the completion of a head movement 
sequence the head is not positioned over the expected track. This 
bit indicates the controller and/or FDD are malfunctioning, and a 
recalibrate diskette operation should be performed. Seek error 
Can occur during any diskette operation. 

CRC Error: 

Bit one indicates the CRC characters generated during a read 
data or verify CRC operation were not the same as the two CRC 
characters appended to the data field when it was originally 
written on the diskette. 

Deleted Record: 

Bit zero indicates that a sector addressed during a read 
data or verify CRC operation was preceded by a deleted data ad- 
dress mark. 

Two other error conditions are provided when more than one 
error bit is true. They are: 

ID CRC Error: 

If the address error and CRC error (bits 3 and l, res- 
pectively) are true, this indicates the CRC characters generated 
during the reading of an ID field were not the same as the CRC 
characters appended to the field when it was written by a format 
track operation. 

Data Mark Error or No Address Mark: 

If the address error, seek error, and CRC error (bits 3, 2 
and 1, respectively) are true, this indicates no address mark or a 
data mark error wasS encountered. This usually means the track has 


not been formatted. 
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Chapter 5 - Controller Operation 


5.1 Introduction 
This chapter is intended to give a brief description of the 


ZX-200A hardware operation and its external interfaces. 


5.2 Interrupts | 
The ZX-200A will generate interrupt requests when allowed by 
certain channel commands (see Chapter 4). Any interrupt (INTO 
through INT7) may be used, but most operating systems, expecially 
ISIS, will require INT2/, This may be selected via jumper (see 


Chapter 2). 


5.3 I/O Base Address Selection 

The I/O base address is fixed by U43, a bipolar PROM. 

For microcomputer development systems using ISIS the re- 
quired address is 78H - 7FH for logical drives :FO:, :Fl:, :F2: 
and :F3:, which are all double density. 

The required address is 88H - 8FH for logical drives :F4: 
and :F5:, which.are both single density, and independently add 


reusable. 


5.4 Drive Interface 
The ZX-200A has been designed to interface readily with the 
Shugart SA800. The 50-pin edge connector is pinned alike with the 


SA800, thus allowing simple ribbon connectors. More than one 


drive may be used by simply paralleling it on a common connector 


and wire system as shown in the following figure. 


Pl 


Drive Drive Drive Drive 
DS4 DS3 DS2 DS1 


Figure 5.1 Ribbon Connection 


Line terminators must be installed for each signal line at 
the last drive unit to use it. In the figure most lines (except 
DS1 through DS3) will be terminated at drive one. 

The table on the following page lists the signals available 


at the drive interface connector Jl. 
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Table 5.1 Signals at Drive Interface Connector Jl 


—  [stenan name | runerion, 


DS1/-DS4/ A low state selects the drive. When active DS1/- 
J1-26 DS4/ allows drives 0 through 3 to accept the 
J1-28 remaining drive input signals and to gate its out- 
J1-30 put back to the ZX-200A. 

J1-32 


WRITE ENABLE/ A low state will allow the data to be written on 
- J1-40 the diskette. When this signal is inactive the 
Write electronics are disabled and the drive reads 

data from the diskette. 


A signal pulsing low will cause the head to step 
one track, for each low-going, in the direction 
determined by DIR/. 


When this line is low the step signal will cause 
the head to move toward the track 76 (step in), and 
when high the head to step out toward the outer- 
most track OO. 


- This is the composite data/clock serial write sig- 
nal. A high-to-low transition on this line indi- 
cates a bit to be written on the diskette. 


me A low on this line indicates the selected drive is 
ready. This is a radial ready circuit. 


An active low on this line indicates a write 
protected diskette is installed in the selected 
= drive. 


INDEX/ A low going pulse is passed on this line that is 
J1-20 coincident with the index hole in the diskette. 


READ DATA/ The composite data and clock signal generated 
J1-46 during a diskette read operation. A high-to-low 
ee going transition indicates a clock or data one bit. 


LOW CURRENT/ Signal to the drive to reduce write current through 
Ay Ji=2 head. Active low for track 43. 


FAULT RESET/ Reset signal to drive to clear fault indicator. 
J1-4 
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Table 5.1 Signals at Drive Interface Jl (continued) 


FUNCTION | 


FAULT/ Fault detected by drive. Signal is input to con- 
J1-6 troller to cause fault routines to execute. 


TWO SIDED/ Signal from FDD to indicate presence of a two sided 
J-10 media. 

SIDE SELECT/ Signal from FDC to FDD to select which side of a} 
J1-14 two sided media operation is to be performed. 


Notes 1-49 odd are all signal grounds. 


5.5 Multibus Interface 


The ZX-200A communicates with the master CPU over the bus 
through the 86-pin connector Pl. Table 5.1 defines Multibus 


Signals used and Figures 5.1 and 5.2 describe signal timings. 


5.6 Board Location Considerations 

The ZX-200A is a Multibus bus master and as such must 
be located in a backplane slot which provides for the BPRN/, 
BREQ/, BUSY, and BCLK signals. Other bus master cards in a system 
will consist of the CPU and DMA boards. Provision must be made 
for the various bus masters to communicate bus requests and grants 
through card arrangements and connections of the above bus sig- 
nals. The most lanl Ye ae resolution scheme is the serial 
type and is typically used in systems with less than four bus 
masters. A jumper should be used at wire wrap position T-V to 

provide BPRO/ output in serial priority schemes. 
Figures 5.1 and 3-2 on the following page show bus access 


timing and 8219 set-up and hold timing. 
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Figure 5.2 Bus Access Timing 


BCLK 
(P1-13) 


‘J 
Si) 


BCR 
(8219-25) 


BREQ 


(P1-18) 


BPRO/ 
(P1-16) 


_—~ 


BUSY/ 
(P1-17) 


ADEN 


(8219-19) 


Figure 5.3 8219 Set-up and Hold Timing 


XCY a" ) a 
(8219-5) _»| ee 7 
MRDC/ or MWTC/ . *I 
(P1-19 OR P1-20) 


XACL/ Se > 
(P1-23) 

XCY —_—— 

(8219-4) 


c ¥ 


Power 
Supplies 


Bus 
Controls 


os 


Power 
Supplies 


TABLE 5.2 MULTIBUS PIN ASSIGNMENTS 


BOARD COMPONENT SIDE 


Signal Ground 
+5 VDC 

+5 VDC 

+12 VDC 

-5 vbC 

Signal Ground 


Bus Clock 

Bus Priority In 

Bus Busy 

Memory Read Command 
1/0 Read Command 
Transfer Acknowledge 
Advance Acknowledge 


Byte High Enable 
Common Bus Request 
Constant Clock 
Interrupt Acknowledge 


Interrupt Requests 


Address Lines 
nol 


Signal Ground 
-10 VDC 

-12 VDC 

+5 VDC 

+5 VDC 

Signal Ground 
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BOARD CIRCUIT SIDE 
| MNEMONTC | DESCRIPTION — . 


ADR10/ 
ADR11/ 
ADR12/ 
ADR13/ 


Signal Ground 
+5VDC 

+5 VDC 

+12 VDC 

-5 VDC 

Signal Ground 


Initialize 

Bus Priority Out 

Bus Request 

Memory Write Command 

1/0 Write Command 

Inhibit (disable) RAM 

Inhibit (disable) ROM or EPROM 


Address 
Extension 
Lines 


Interrupt Requests 


Address Lines 
nae 


Signal Ground 
-10 vDC 

-12 vpc 

+5 VDC 

+5 VDC 

Signal Ground 


Table 5.3 Multibus Signals Descriptions 


Signal 
Mnemonic 


AACK/ 
ADRO/-ADRF/ 


ADR10/-ADR13 


BCLK/ 


BHEN/ 


BPRN/ 
BPRO/ 


BUSY/ 
CCLK/ 


Functional Description 


Advanced Acknowledge. This signal is an advanced 
indication that the requested Read or Write opera- 


tion will be completed in a specified time (taack)> 


Address. These 16 lines are used to transmit the 
address of the memory location or I/O port to be 
accessed. ADRF/ is the most significant bit. 


Address Extension. These four lines are appended 
to the address to allow accessing of megabyte 
memories. 


Bus Clock. The high-to-low transition of BCLK/ is 
used to synchronize bus contention resolution 
Circuits. BCLK/ is asynchronous to the CPU clock. 
It has a minimum period of 100 nanoseconds anda 
35% duty cycle. BCLK/ may be slowed, stopped, or 
Single stepped for troubleshooting. 


Byte High Enable. Indicates use of data lines 
DAT8-F. 


Bus Priority In. Indicates to a particular master 
module that no higher priority module is requesting 
use of the bus. BPRN/ is synchronized with BCLK/. 
This signal is not bussed on the backplane. 


Bus Priority Out. Used with serial (daisy chain) 
bus priority resolution schemes. BPRO/ is passed 
to the BPRN/ input of the master module with the 
next lower busy priority. BPRO/ is synchronized 
with BCLK/, This signal is not bussed on the 
backplane. 


Common Bus Request. Indicates a master module, not 
currently in control, requests use of the bus. 


Bus Busy. This signal is driven by the bus master 
currently in control to indicate that the bus is in 
use. BUSY/prevents all other master modules from 
gaining control of the bus. BUSY/ is synchronized 
with BCLK/. 


Constant Clock. Provides a clock signal of con- 
stant frequency for unspecified general use by 
modules on the bus. CCLK/ has a minimum period of 
100 nanosconds and a 35% to 65% duty cycle. 
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Table 5.3 - Multibus Signal Descriptions (continued) 


Signal 

Mnemonic Functional Description 

DATO/-DATF/ Data. These 16 bi-directional lines transmit or 
receive information to or from a memory location or 
I/O port. DATF/ is the most significant bit. In 
eight bit systems only lines DATO/-DAT7/ are used, | 
in which case DAT7/ is the most significant bit. 


INH1/ Inhibit RAM. Prevents RAM devices from responding 
to the memory address on the address lines. INHI1/ 
effectively allows ROM devices to override RAM 
devices when ROM and RAM are assigned the same 
address space. INH1/ may also be used to allow 


memory mapped I/O devices to override RAM. 


INH2/ Inhibit ROM. Prevents ROM devices from responding 
to the memory address on the address lines. INH2/ 
effectively allows start-up software such as ROM 
based bootstrap programs to override another ROM 
device when the two ROMS are assigned the same 

| address space. INH2/ may also be used to allow 


memory mapped I/O devices to override ROM. 


Initialization. Resets entire system to a known in- 
ternal state. INIT/ may be driven by one bus mas- 
ter or by an external source such as a front panel 
reset switch. 


INTO/-INT7/ Interrupt. Each of these eight lines causes the 
Master processor to generate INTA as defined below. 
INTO/ has the highest priority; INT7/ has the 
lowest priority as assigned by an interrupt 
priority resolution network. 


I/O Read Command. Indicates that the address of an 
input port has been placed on the address lines and 
that the data is to read from the data lines. 
IORC/ is asynchronous with BCLK/. 


Memory Read Command. Indicates the address of a 
memory location has been placed on the address line 
a data word (eight or 16 bits) is to be read from 
the data lines. MRDC/ is asynchronous with BCLK/. 


Memory Write Command. Indicates that the address 
of a memory location has been placed on the address 
lines and that a data word (eight or 16 bits) has 
been placed on the data lines. MWTC/ specifies 
that the data word is to be written into the 
addressed memory location. MWTC/ is asynchronous 
with BCLK/. 
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Table 5.3 - Multibus Signal Descriptions (continued) 


Signal 
Mnemonic Functional Description 
XACK/ Transfer Acknowledge. The required response of 


memory location or I/O port to indicate that the 
specified read/write operation has been completed. 
That is, data has been placed on, or accepted from, 
the data lines. XACK/ is asychronous with BCLK/. 


Figure 5.3 shows an implemented serial priority network. In 
this type of arrangement the bus master with the highest priority 


Can be identified by its pin 15 (BPRN/) being grounded. 


Highest Lowest 
Priority Priority 


Pigure 5.3 Implemented Serial Priority Network 


In the above figure, the master in slot Jl will drop BPRO/ 
low to paSsS priority grant on to J2 if the master in Jl is NOT 
requesting the bus. BUSY/ will be high if no master is currently 
using the bus. If the master J2 doesn't need the bus, it will 
drop its BPRO/ low to cause J3 BPRN/ to go low and thus grant a J3 
request. If J2 requests the bus it will raise its BPRO/ high and 
wait until its BPRN/ goes low, BUSY/ goes high, and BCLK/ does a 
negative transition. J2 will then latch BUSY/ low and that will 
disallow even higher priority master requests until J2 drops its 


use of the bus. 


41 


Higher speed and bus contention resolution schemes involving 
four or more masters use a parallel priority network. BREQ/ 
Signal is output to an SN74148 (typical) priority encoder. Then 
an SN74S138 (typical) decoder outputs a master's BPRN/ for input 
grant. 

5.7 Controller Features 

The Zendex ZX-200A Multibus floppy disk controller emulates 
and enhances the Intel iSBC 202 Double Density and iSBC 201 Single 
Density floppy disk controllers. A single CONTROLLER card can 
replace both sets of boards (each Intel controller consists of two 
boards, the channel and interface cards) in an Intel Intellec MDS 
system and interfaces as many as four floppy disk drives. These 
drives can be single or double sided with single or double density 
fomat diskettes. The operator does not need to enter any commands 
to indicate the recording density of the diskette to be read from 
Or written to. 

From the system's perspective, the CONTROLLER appears as two 
separate controllers, one for single density diskettes and one for 
double density diskettes. Typically, each of the controllers is 
accessed via a different port address. Usually, these addresses 
fall in the following ranges: 


Single density: 88 - 8F hex 
Double density: 78 - 7F hex 


The resident CONTROLLER firmware decodes the address to 
determine the recording density of the diskette. However, there 
are circumstances where the address range for the single density 
controller is 78 - 7FH. The firmware has been written to accommo- 


date this configuration as well. (See Note on following page.) 
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Note: the first revision of the CONTROLLER 
firmware does not support single density operation 


from port 78H. 


Data to be read from or written to the disk is fully buf- 
fered. The CONTROLLER contains 1K of static RAM éemporarily 
Storing the data for transfer. This means two things to the 
system designer: (1) the chance of a data overrun or underrun is 
completely removed, and (2) the controller cannot get control of 
the system bus in time for a byte of data read from the disk to be 
transferred to system RAM (data is transferred ona byte by byte 
basis). Consequently, that byte disappears as the next one is 
read from the disk and moved to RAM (assuming the controller gets 
control of the bus in time to transfer this byte). Data underrun 
is similiar, but occurs during a disk write operation. With the 
CONTROLLER, the entire sector (128 bytes) is written to the on- 
board RAM independently of the system bus. Data is transferred to 
system RAM with a DMA controller. If this gets interrupted by a 
higher priority component, the DMA controller keeps a record of 


the last location transferred, so that when it has control ofthe 


bus again, it can begin where it left off. 


The rate of data exchange is 250K bits per second in single 
density and 500K bits per second in double density. Single den- 
sity recording uses the standard IBM 3740 format. This format 
uses the frequency modulation (FM) recording technique and speci- 
fies 26 sectors of 128 bytes of data per track. In double 
density, MMFM (modified-modified frequency modulation) recording 


is used with 52 sectors of 128 bytes per track. 
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5.8 Controller Operation 

The ZX-200A CONTROLLER firmware responds to ten I/O addres- 
ses output by the CPU. These addresses typically appear between 
78 - 7FH for double density operation, 88 - 8FH for single density 
operation. In some circumstances 78 - 7H is also used for single 
density. The CONTROLLER firmware can interpret these addresses as 
well. (Note: these ports can be changed by inserting a different 
I/O address decode PROM u43). Of the eight available ports in 
each range, only five are used. The CPU selects one of seven 
disk-related operations by outputting to the port associated with 
that operation. 

The CONTROLLER operates as a system within the system. It 
contains a 8085A processor, which executes the requested disk 
operation via a memory-map. For instance, a read sector command 
from the CPU requires a number of processes be performed in ad- 
dition to the read operation (for example, move head to track, 
synchronize with the disk, read data, read and compare CRC, etc.) 
Each of these functions is enabled by an output to the port within 
the CONTROLLER dedicated to it. | 

When the command requests a disk read or write, two DMA 
operations follow. First, the seven or ten bytes of the I/0 
Parameter block (IOPB) are moved toa 1K RAM buffer on the CONTRO- 
LLER RAM buffer. A resident 8257 DMA controller performs this 
task. Once it has control of the system bus from the CPU, the 
whole content of the data buffer is transferred to system RAM for 
a disk read or vice versa for a disk write. The requisite bus 


Signals are generated to access memory. If the controller is 
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interrupted by a higher priority component in the system, the 8257 
"remembers" the last byte transferred. When it has regained 


control of the bus, the next byte is transferred. 


The CONTROLLER operates in two modes: 

(1) when it hasn't been selected to perform a disk related 
function, it is in the IDLE MODE. In this mode, it is constantly 
looping through a routine,which checks the status of the disk 
drives. If a change in the status is noticed (a disk is removed 
Or inserted, for instance), an interrupt is sent to the CPU to 


register the change. 


(2) During program execution, the CONTROLLER is selected: 
- to perform diskette reads and writes 
- to be reset 


- to stop permaturely a group of linked disk operations 
(in single density operation only) 


- to render disket drive status to the CPU 


- to indicate the result of an operation to the CPU 


Each of the above operations is initiated by a CPU output toa 
specific port. There are two base addresses, one for single 
density operation and one for double density. (Although the 2X- 
200A CONTROLLER reads or writes in both densities, Intel has 


separate floppy disk controllers for each density.) 
Note: The base port for the Intel single density 
controller is address 88H; the base port for the 


double density controller is at 78H. 
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Figure A - 2ZX-85 Minimum Diskette System 
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ZX-200A MAP 23 LISTING 


8 9 A BC D E F 


4 5 6 7 


Addr 


Fy Fay Gey Fey Fey Fy fey OD OD fay Fey fe Fy fy Py 
Foy Fea Gey Fey Fea Gy Fey Gey Gy Fey Fae Fey Fey Gey fry fy 
Fey Coy Fey Fey Gey Fey Fey Fey Fey Gey Fey Gey Fey Bey ey fy 
Foy Fy Fey Fey Ge Fy Fg Foy Gay Fey Fey Py Fey Bey By fy 
Fa aa fay Gea Cog fy Gg Ps Gy Cay Bay Fae ae fae fs 
Fog Fag Fy Gey Fag Gy Fag PS A ey Fey Fay fey fey fy fy 
Fg Gey Fay Fey Gey Fy Fay + Fee Fey Fey fey Py fy By 
Py Coy Fey Fey Gay Fey Fey DO RQ fy fy fr Gy fe Py 
Foy Fay Fay Fey Gy Gy Foy Fey Gy See Gey Pea Fey Fey Fy fy 
Fey Fey Fey Fey Gy Gey Gy Fey Gay Fey Fey Gey Fey Fay fry fy 
Foy Fey Fey Coy Gey Gey Gu Fey Fay Fay Fey Fey Foy Fey fy Oy 
Foy Fey Fey Fey Fey By Fey Fey Gy Fey Fey Gey Fey Fey Fey fey 
Fay Gey Gey Fay Fey Fey Gey Fey Bey fey Gey Fey Bey Py By By 
Fey Fay Gy Fey Fey Gey Fey Fey Gey Fy Fey Gry Fey Fey Fy fy 
Fy Fay Gy Fey Gey Gy Boy Gey Fy Fey Fey Fey Fey ey ey fy 


Foy Fy Gy Fey Gey Gey Fey Gey Fee ey Gey Gey Foy fy Fey fy 


_ 


6 7 8 9 A B C D E F 


oe ee ee oe OO © 6 © om oe a OF Om Om OF © OF Om @ © BE Oe OF © C= OF © OO © ow © Ow we Se © Oe Oe OD OF Se = Ow Oe Oo = oe 


Addr 


Fag Fey Fay Fey Fey Fey Fay Fey Fey Gey Gey fey Fey es Fy Cy 
ey Gy Coa Foy Cy Fey Fey Fey fy Fey Foy Bey fee Pay Foy Fy 
Gey Fey Fey Fey Gy Gey Gy ey Fey ee Gee Coy Pee eu fey fy 
Fey Fog Gey Fey Gy Fey Gay Fey fey Fey Gey Foy ey Fea Fey fou 
Fy Gey Gg Fea ey Fey Fey Fy Fey Fey Fey fey Fey Fey fay fy 
Fg eq Fea Fy Fg Gy Fy Gey Fey Fey Gey Gey Fy Fey Foy fa 
Fey Coy Fey Fea Fey Fey Gey Fey Fey Fey Fey Fay Fey Fey Bey fey 
Gey Ging Fy Fou Fey Gey Fey Fey Fy Fey Fee Fey Fey Fy fy ey 
Pog Fy Fey Gy Coy Fy Fy Gey Fey Gea fey Coy Fay ey Bey By 
Poy Fay Fey ey ey Fay Fey Gy Fey Fay Cy Fey Fey Fey fea fy 
Fay Gey Baa Gy Fey Fy Fey Gey Py Fey Fey Fey Fey fey Ey fy 
Fg Fag Gey Fea Gy Fy Gg Fey Fey Gey fey Fey fey fey Foy fou 
fy Fey Fey Coy Fey Fey Fey Foy Fey Fey Fey Gey Gey fey ey Gy 
Fry Fy Cy Fy Gey Fey Fg Fey Fey Fay Fy Fey Gey Fey fey fy 
Cea a Fey Fen Fou fy fa Fg Cay Fry Feu Fy Fea Fan fx fy 
Fy Gey Gg Fey Fey Fey Fey Fey Fey Fey Fey Fay Feu fey fy By 
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ZX-200A MAP PROM LISTING 


MAP 20 
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0066 
0066 
0067 
0067 
0080 
2000 
2001 
2008 
6000 
6100 
6200 
6300 
6300 
6401 
6402 
6403 
6400 
6500 
6500 


O7FF 
O7FF 
0000 


0000 


DB80 


we we We we We we we we we 
a 


we 


we We woe CWS We Ce we WO we WO we We we wo we We WS we 


#001 ZX=-200A FLOPPY CONTROLLER V1.2 


TITLE *ZX-200A FLOPPY CONTROLLER V1.2! 
MACLIB 18085 

MOD85 

XREF 


REVISION: 10/02/81 BY S.R. 
VERSION 1.2 

LAST MODIFIED AUG 6, 1981 
RICK MAIN, PGMR 


ZENDEX CORPORATION 

6680 SIERRA LANE 

DUBLIN, CA 94566 
(415) 829-1284 


TWX 910-389-4009 


KKFKKEKKKKKATKKLEKTKLKARAKLKAKLAFTFRKKKTLKKKELTTKKKERKKKKKKKEKKKKERERKKRRARAKLAS 


THIS PROGRAM IS ORGANIZED TO RUN IN THE ZENDEX 
ZX-200A FLOPPY DISK CONTROLLER. THE FIRMWARE IS 
CONTAINED IN A SINGLE 2716 EPROM. 


PORT EQUATES 


5 HH OE aE HE aE He a A aE a aa a aaa aaa a aa aa aa aaa 


RDSTAT 
WRCONT 
RDRDY 
WRCNT1 
CLRINT 
DMADDR 
DMATC 
DMAMOD 
MRKCRC 
MARK 
DISKIO 
WRCRC 
SYNCPL 
PORT8B 
PORT79 
PORT7B 
PORT89 
WRCLK 
RDPRT1 


ZX202: 


EQU 66H ; READ FDD I/F STATUS 
EQU 66H ; WRITE FDD I/F CONTROL 
EQU 67H ; READ INT & FDD READY STATUS 
EQU 67H ; WRITE INT CLR & WR ENABLE, HEAD LOAD 
EQU 80H ; CLEAR RST INTERRUPT FLIP-FLOP 
EQU 2000H ; DMA BASE ADDRESS 
EQU 2001H ; DMA TERMINAL COUNT ADDRESS 
EQU 2008H ; DMA MODE SET REGISTER 
EQU 6000H ; READ/WRITE MARK/CRC BYTE 
EQU 6100H ; READ/WRITE MARK 
EQU 6200H ; IO DISK DATA 
EQU 6300H ; WRITE CRC 
EQU 6300H ; READ SYNC PLO 
EQU 6401H ; PORT 8B TO HOST 
EQU 6402H ; PORT 79 TO HOST 
EQU 6403H ; PORT 7B TO HOST 
EQU 6400H ; PORT 89 TO HOST 
EQU 6500H ; WRITE CLOCK 
9 


EQU 6500H READ 4X4 FILE PORT 


ORG 7FFH ; SET VERSION STAMP AT LAST ADDRESS 
DB 12H ; FOR VERSION 1.2 
ORG 0 ; BEGIN AT RESET POINT 


IN CLRINT ; CLEAR INTERRUPTS TO HOST 
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0002 
0003 
0006 


0009 
000A 
000B 
OO0E 
0010 
0012 


0015 
0017 
OO1A 
001B 
001D 


0024 
0024 
0025 


002C 
002C 
002F 
0031 


0034 
0037 
0039 


003C 
003C 
003D 
0040 
0042 
0045 


AF 
310042 
210040 


tT 

2c 
C20900 
DB67 
E60F 
321440 


3EFF 
320D40 
AF 
D367 
C35400 


F5 
C34A00 


2A0165 
DB80 
C3C000 


2A0164 
DB80 
C39C00 


F5 
3A0040 
E6FB 
320040 
3E10 


0047+30 


0048 
0049 


OO4A 
OO4D 
OO4E 


F1 
cg 


3A1340 
3D 
321340 


0051+20 


0052 
0053 


F1 
cg 


RAMCLR: 


DSKCLR: 


NDEX: 


MAT78: 


LHA: 


L543 


#002 

XRA A 

LXI SP, 4200H 
LXI H, CHANWD 
MOV M,A 
INR L 

JNZ RAMCLR 
IN RDRDY 
ANI OFH 
STA RDYBIT 
MVI A, OFFH 
STA UNIT 
XRA A 

OUT WRCNT1 
JMP L54 
TRAP INTERRUPT 
ORG 24H 
PUSH _PSW 
JMP LYA 
ORG 2CH 
LHLD  6501H 
IN CLRINT 
JMP LCO 
RESTART 6.5 
LHLD = PORT8B 
IN CLRINT 
JMP LOB 
ORG 3CH 
PUSH PSW 
LDA CHANWD 
ANI NOT 4 
STA CHANWD 
MVI A, 10H 
SIM 

DB 30H 
POP PSW 
RET 

LDA INDXCT 
DCR A 

STA INDXCT 
RIM 

DB 20H 
POP PSW 
RET 


we we 


ZX-200A FLOPPY CONTROLLER V1.2 


INITIALIZE STACK POINTER 
CLEAR BUFFER, FLAGS 


LOOP TILL BUFFER CLEARED 
READ INT. & FDD READY PORT 


READY STATUS 


CLEAR HOST INTERRUPTS AND UNLOAD HEAD 


TRAP INTERRUPT SOURCE FROM FDD INDEX MARK 


MEMORY ADDRESS UPPER WRITTEN BY HOST FOR SD 


READ IOPB ADDRESS FROM 4X4 
RESET RST F-F 


MEMORY ADDRESS UPPER WRITTEN BY HOST FOR DD 
READ IOPB ADDRESS FROM 4X4 
RESET RST F-F 


STOP OPERATION INTERRUPT FOR SD DRIVES ON 88 
RESET LINK BIT IN IOPB CHANNEL WORD 


RESET RST 7.5 FF 


DECREMENT INDEX COUNT FLAG BY ONE FOR EACH 
REVOLUTION OF DISK, RST SOURCE INDEX MARK. 
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0054 
0056 


3E08 
FB 


0057+30 


0058 
OO5A 
005B 
005D 
0060 
0061 
0063 
0066 
0067 


006A 
006D 
006E 
0071 


0074 
0075 
0076 
— 0077 
0078 
0079 
OO7A 
007B 
007C 
OO7E 
OO7F 
0082 
0085 
0087 
008A 
008D 
0090 
0091 
0094 


0096 
0098 
009A 
009B 


009C 
009D 
OOAO 
00A3 
00A5 
00A8 
OOAA 
OOAC 
OOAE 


DB67 
47 
E6CO 
C26 A00 
78 

E6 OF 
211440 
BE 

C47 400 


341340 


321340 


L6A: 


DYINT: 


L95: 


LOB: 
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A,8 


H, RDYBIT 


M 
RDYINT 


INDXCT 
A 

L54 
DSKCLR 


INTERRUPT HOST 


MOV 
RRC 
RRC 
MOV 


INDXCT 


we we we we 


(2) 
= 


we we we we we We we We We we 


we we We we we w we 


OPEN UP ALL RST X.5 INTERRUPTS 
SET INTERRUPT MASK 
READ INT. & FDD READY PORT 


ISOLATE INT PND BITS 
JUMP IF INT PND 


ISOLATE DRIVE READY BITS 
; READY STATUS 
SEE IF OLD READY=NEW READY 
JUMP TO DO UPDATE/INTERRUPT IF NOT 


_ INDEX COUNT 


REV COUNT EXPIRED? 
NO, LOOP 
YES, DESELECT DISK UNIT 


READY CHANGE 


FORMAT UNIT READY BITS 


WRPORT 8B, SD RESULT BYTE 
WRPORT 7B, DD RESULT BYTE 
RESULT TYPE = 2 

WRPORT 89 RESULT TYPE SD 
WRPORT 79 RESULT TYPE DD 
TEST FOR INITIALIZATION CODE 
WAS IT FF? 

RESET WR2D IF INIT 

SET WR2D 

SEND BOTH INTERRUPTS TO HOST 


DD PROCEDURE 


; DISCARD RST CALL RETURN 


CALL DD DISK OPERATION 
STORE IN 7B, RESULT BYTE 
STORE TYPE 0 RESULT 

PORT 79H(HOST) 

TURN OFF WRITE ENABLE 


DELAY DESELECT 8 DISK REVS 
INDEX COUNT 
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00B1 
OOB4 
00B6 
0OB9 
0OBB 
OOBD 


00CO 


00C1 
00C2 
00C5 
00C6 
00C9 
00cCc 
0O0CD 
OOCF 
00D2 
00D5 
00D6 
OOD7 


0OD9 
OODA 
OODB 
OODE 
OODF 
0OEO 
00E3 
O0E5 


3A0040 
E610 
C25400 
3E44 
D367 
C35400 


D1 


320164 


47 


3D 

2F 
320064 
F1 

B7 
C43C00 
3E0D 
FB 


00E6+30 


00E7 
OO0E9 
OOEB 
OOED 
OOFO 
OOF 1 
00F2 
OOF3 
OOF6 
OOF9 
OOFA 
OOFC 
OOFD 
OOFF 
0100 
0101 
0104 


0107 
0108 
0109 
010B 
010E 
0111 


3E04 
D367 
3E08 
321340 
78 

F5 

07 
DA0701 
2A0B40 
E5 
2643 
OF 
F601 
TT 

E1 
010040 
CDF901 


Ey 

47 
F620 
C21D01 
2A0840 
78 


LCO: 


LCi: 


LODA: 


L108: 
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CHANWD 
10H — 
L54 
A, 44H 
WRCNT1 
L54 


PORT89 
PSW 

A 

STOP 
A, ODH 


30H 
A,4 
WRCNT1 
A,8 
INDXCT 
A,B 


we we wo we 


ISOLATE INTERRUPT CONTROL 
RETURN TO MAINLINE IF DISABLED 
OTHERWISE SET INT 78 


SD PROCEDURE 
DISCARD RST CALL RETURN 


DISABLE ALL BUT INDEX TRAP 

DO SD DISK OPERATION 

SAVE RESULT CODE ON STACK 

WRITE RESULT BYTE TO HOST PORT 8BH 
ISOLATE SUCCESSOR BIT 


BLOCK NUMBER 
MERGE ADJUSTED BLOCK NUMBER IN RESULT TYPE 


EVENTUAL TYPE 2 

FINAL RESULT TYPE 

WRITE FOR HOST READ PORT 89H 
POP ERROR CODE TO ACC 
ERRORS=NOT 0 

CALL LINK CANCEL IF ERROR 
MASK ALL BUT RST 6.5(SD CMD) 


SET INTERRUPT MASK 


CLEAR WRITE ENABLE 


INDEX COUNT 
SAVE CHANWD ON STACK 


TEST LOCK OVERRIDE BIT 

JUMP IF OVERRIDE SET 

SET WAIT BIT IN HOST IOPB CHANWD 
INDEX 2114 BUFFER 


SET WAIT BIT 
PUT BACK IN 2114 BUFFER 


USE DMAC TO WRITE HOST 
POP CHANWD 
ISOLATE INTERRUPT CONTROL 


JUMP IF INTERRUPT NEEDED BY HOST 
NEXT IOPB ADDRESS 
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0112 E604 
0114 C2C100 
0117 78 
0118 E610 
011A C25400 


011D 3E84 
011F D367 


0121 3A0040 
0124 E604 
0126 CA5400 
0129 3E0A 


012B+30 
012C DB67 
012E F680 
0130 C22101 
0133 2A0840 


~ 0136 C3C100 


0139 CDE301 
013C 3A0140 
013F OF 
0140 OF 
0141 OF 
0142 OF 
0143 E603 
0145 4F 
0146 1E04 
0148 3E0B 
O14A 321640 
O14D 3EFF 
O14F C38401 


0152 2A0840 
0155 OF 
0156 DA6101 
0159 060A 
015B CDBF02 
015E 2A0B40 


0161 220B40 
0164 CDE301 
0167 3A0040 
016A OF 
016B DA5201 
016E 3A0140 
0171 OF 
0172 OF 
0173 OF 
0174 E606 
0176 4F 
0177 OF 
0178 AQ 
0179 E603 


L11E: 


L122: 


L13A: 


L153: 


L162: 


ZX=-200A 


\ 
LC1 
A,B 
10H 
54H 


A, 84H 
WRCNT1 


CHANWD 
4 

L54 

A, OAH 


30H 
RDRDY 
80H 
L122 
NXIOPB 
LC1 


L1D7 
DKINST 


NXIOPB 


L162 
B, OAH 
DELAY 
400BH 


400BH 
L1D7 
CHANWD 


L153 
DKINST 


FLOPPY CONTROLLER V1.2 


we we @~e we we 


we we we we We we we 


we we we we 


~w~e we we 


? 


° 
9 
° 
? 


ISOLATE SUCCESSOR BIT IN CHANWD 
JUMP IF LINKED 


ISOLATE INTERRUPT DISABLE BIT 
JUMP IF INTERRUPTS DISABLED 


SET INTERRUPT 88 


ISOLATE SUCCESSOR BIT 


RETURN TO IDLE LOOP IF NOT LINKED 
SET RST 6.5 MASK 


READ INT. & FDD READY PORT 
ISOLATE INT 88 BIT 

LOOP TILL FALSE, HOST MUST ACK 
NEXT IOPB ADDRESS 


FETCH IOPB FROM HOST TO BUFFER 
LOAD UNIT NO. SELECTED BY HOST. 


ISOLATE UNIT NUMBER 

SAVE INC 

SEND DD MODE TO WRCONT1 PORT 
SPECIFY DD DATA ADDRESS MARK 
DATA ADDRESS MARK STORE 

SET DD FLAG MODE 

GO AROUND L153 


NEXT IOPB ADDRESS 

TEST BRANCH BIT 

IF SET, BRANCH TO LINKED IOPB 
OTHERWISE IDLE 10 MS 


RESTORE ORIGINAL IOPB ADDRESS 


SAVE AS ADDRESS OF IOPB TO EXECUTE 
MOVE HOST IOPB TO OUR BUFFER 
FETCH CHANNEL WORD — 


JUMP IF WAIT BIT SET 
FETCH OPCODE 
POSITION & ISOLATE UNIT SELECT BITS 


; INTERMEDIATE TO C 


COMBINE 
MASK 00=0, 11=1, 01&10 ILLEGAL 
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017B 4F MOV C,A ; 

017C 1E05 MVI E,05H ; SEND SD MODE CONTROL TO WRCONT1 PORT 

017E 3EFB MVI A,OFBH ; SPECIFY SD DATA ADDRESS MARK, FOR USE LATER 

0180 321640 STA DAMARK ; DATA ADDRESS MARK 

0183 AF ; XRA A ; ACC=0, FLAG SD OPERATION 

L185: 

0184 321240 STA DDSDFL ; STORE SD/DD FLAG PASSED IN ACC. 

0187 21DB01 LXI H, UNITAB ; DO INDEX TO UNIT SELECT TABLE 

018A 0600 MVI B,0O ; MSD=0 

018C 09 DAD B ; DOUBLE INDEX, TWO ENTRIES PER ITEM 
018D 09 DAD B 

018E 56 MOV D,M ; MOVE SELECT CODE TO D 

018F DB67 IN RDRDY ; READ INT. & FDD READY PORT 

0191 A2 ANA D 3; TEST FOR READY ERROR 

0192 3E80 MVI A,80H ; ANTICIPATE BY WRITING ERROR CODE IN ACC. 

0194 CO RNZ ; RETURN IF READY ERROR 

0195 C5 PUSH B 

0196. 23 INX H ; OTHERWISE FETCH NEXT ITEM IN UNIT TABLE 

0197 TE MOV A,M 

0198 D366 OUT WRCONT ; WRITE FDD CONTROL PORT TO SELECT THAT DRIVE ie 

019A 320A40 STA 400AH ; ALSO SAVE SELECT CODE FOR LATER USE 

019D 3A0D40 LDA UNIT ; FETCH LAST UNIT CODE 

01A0 BY CMP C ; SAME? 

01A1 79 MOV A,C 

01A2 320D40 STA UNIT ; SAVE NEW CODE 

01A5 7B MOV A,E ; SET DD OR SD MODE AND HEAD LOAD 

01A6 D367 OUT WRCNT1 

01A8 0623 MVI B,23H ; CALL DELAY FOR HEAD TO SETTLE IF NEW UNIT 

01AA CHBFO2 CNZ DELAY 

O1AD C1 POP B 

O1AE 211A40 LXI H,401AH 

01B1 09 DAD B 

01B2 7E MOV A,M 

01B3 36FF MVI M, OFFH 

01B5 B7 ORA A 

01B6 CCD502 CZ RECAL 

01B9 21CB01 LXI H,CTAB ; BASE INDEX TO COMMAND TABLE 

01BC 3A0140 LDA DKINST ; FETCH OPCODE 

O1BF 07 RLC ; INDEX BY TWO'S 

01CO E60E ANTI OEH ; ISOLATE OPCODE BITS 

01C2 5F MOV E,A ; ADD TO CTAB BASE ADDRESS 

01C3 1600 MVI D0 

01C5 19 DAD D 

01C6 5E MOV E,M 

01C7 23 INX H 

01C8 56 MOV DM 

01C9 EB XCHG 

01CA EQ PCHL ; JUMP TO COMMAND PROCEDURE 

CTAB: 

01CB OD02 DW L20C ; NOP 

01CD 7C02 DW SEEK ; SEEK 

O1CF 1605 DW FORMAT ; FORMAT 

01D1 D502 DW RECAL =; RECALIBRATE 

01D3 F702 DW READ ; READ 

01D5 F702 DW READ ; VERIFY CRC 

01D7 0203 DW WRITE ; WRITE 
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01D9 FBO2 DW WRITDL ; WRITE DELETED DATA 
UNITAB: 
01DB 01 DB 1 ; UNIT 1 
~O1DC BF DB NOT 40H 
J1DD 02 DB 2 ; UNIT 2 
O1DE DF DB NOT 20H 
O1DF 04 DB 4 ; UNIT 3 
O1EO EF DB NOT 10H 
01E1 08 DB 8 ; UNIT 4 
01E2 F7 DB NOT 8 
L1D7: 
01E3 010980 LXI B,8009H ; SELECT HOST READ, 9 BYTES 
01E6 CDF901 CALL DMALOD ; INVOKE DMA TRANSFER 
O1E9 2643. . MVI H,43H ; ADDRESS ON-BOARD BUFFER 
01EB 110040 LXI D, CHANWD ; POINT TO IOPB CHANNEL WORD 
O1EE OEOA MVI C,10 ; MOVE 10 BYTES FROM DMA BUFFER TO IOPB ARRAY 
L1E6: 
O1FO 7E MOV A,M ; READ BUFFER 
™O1F1 12 STAX D ; STORE AT IOPB 
O1F2 13 INX D ; ADJUST POINTERS 
01F3 2C INR L 
O1F4 OD DCR C ; DECREMENT COUNTER 
O1F5 C2F001 JNZ L1E6 
01F8 C9 RET 
DMALOD: 
O1F9 97 SUB A 
O1FA D365 OUT 65H ; CLR EXTENDED ADDRESS 
. OWE ES - PUSH H ; SAVE HL 
O1FD EB XCHG 
O1FE 210020 LXI H, DMADDR ; SEND TO 8257 DMA REG PORT 
0201 73 MOV M,E 
0202 72 MOV M,D 
0203 23 INX H ; POINT TO TC PORT 
0204 71 MOV M,C ; WRITE TC AND CYCLE CODE 
0205 70 MOV M,B 
0206 3E41 MVI A,41H ; WRITE MODE WORD, TC STOP BIT & CHAN. O ENABLE 
0208 320820 STA DMAMOD 
~020B Et POP H ; RESTORE DMA ADDRESS 
020C C9 RET 
L20C: 
020D CD7C02 CALL SEEK ; DO SEEK 
0210 BT ORA A ; TEST ERROR 
0211 CO RNZ ; RETURN IF ERROR 
0212 3A0240 LDA NUMRCD ; LOAD # RECORDS 
0215 E607 ANI 7 
0217 O7 : RLC 
0218 AF MOV C,A 
0219 0600 MVI B,0 
021B 212402 LXI H, L223 
021E 09 DAD B 
O21F 5E MOV E,M 
0220 23 INX H 
0221 56 MOV D,M 
“0222 EB XCHG 


0223 EQ PCHL ; EXECUTE PROCEDURE 
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3402 
3B02 
4102 
4702 
5702 
5C02 
6302 
6802 


110062 
1A 
C33702 


110061 


C3 3702... 


110062 
C3402 


110061 


C8 
3A0440 


12 
C35302 


OE00 
C35E02 


OEFF 


0680 
C36C02 


OE00 
C36A02 


OEFF 
0640 


C5 
OEFF 
240540 
CDF901 
C1 

AF 

B1 
C26C02 
C9 


L223: 


L233: 
L236: 


L23A: 
L240: 


L246; 


L249: 


L252: 
L256: 
L25B: 
L25D: 
L262: 


L267: 
L269: 


L26B: 


RET 


1268 


G0 
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L233 
L23A 
L240 
L246 
L256 
L25B 
L262 
L267 


D,DISKIO 
D 


_ L236 , 


D,6100H ; 
L236 3 
D, DISKIO 
L249 


D,MARK ; 
BaTUrS 


_WRENBL ; 


D 
SCTADR ; 


D cated 
L252 


C,0 
L25D 


C,OFFH ; 


B, 80H 


L269 


C,OFFH ; 


| B,40H °; 


* 
C,OFFH 
BUFFER 
DMALOD 
B 
A 
C 
L26B—; 


@e we We we we 


; RD DISK 
RD DISK + X 
LOOP 


RDMRKA 
GO INTO LOOP 


; RD DISK 


RDMRKA 
ENABLE WRITE CONTROLS: 


RETURN IF WRITE PROTECTED 
LOAD SECTOR ADDRESS 


WRMRK (CRC) 


DMA 256 BYTES 


READ FROM HOST RAM _ 


_NO DATA TRANSFER 


256 BYTES | 


WRITE TO HOST RAM 


256 BYTES 4 
LOAD BUFFER ADDRESS 
MOVE DATA 
RESTORE BC 

ACC=0 


JUMP IF NOT ‘A VERIFY CYCLE 


SEHELELELSLEHKEKEREEREREAALELALAALEEERELEEHERETERRAAAEKHSEEREERLEEKEEEE EE 
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027C 
027F 
0280 
0283 
0284 
0286 
0288 
0289 
028A 
028C 
028F 
0292 
0293 
0295 


0296 


0299 
029A 
029B 
029C 
029F 


02A2 
02A5 
02A8 
O2AA 
O2AB 


O2AC 
O2AD 
O2AF 
02B0 
02B1 

0253 
02B4 
02B6 
02B8 
02B9 
02BB 


02BD 
O2BF 


02C1 
02C2 
02C5 
02C6 
02C9 


3A0340 
B7 
CAD502 
57 
FED 
3E08 
DO 

TA 
FE2B 
DA9602 
210A40 
TE 
E6FB 
ca 


CDCA02 


TA 
96 
c8 
CDA202 
C39902 


3A0A40 
DAACO2 
E6FD 
34 

34 


C2BF02 
C9 


TA we we we wo we 


Sie 


S2: 


STEP: 


L2AB: 


#009 


ZX-200A FLOPPY CONTROLLER V1.2 


SEEK A TRACK~ THE BYTE IN TRKADR IS USED TO DETERMINE THE 


THE TARGET TRACK TO STEP TO. 


IF ZERO RECALIBRATE IS USED 


INSTEAD. ENTERED DIRECTLY AS A HOST COMMAND OR AS A PRELUDE 
TO ANOTHER OPERATION FOR IMPLIED SEEK. 


LDA 
ORA 
JZ 

MOV 
CPI 
MVI 
RNC 
MOV 
CPI 
JC 


TRKADR 
A 
RECAL 


WRCONT 
A 


WRCONT 


1 
WRCONT 


2 
WRCONT 


we 


we we WS we WO 


we we we we we WE 


we we ed w2e 


SEEK OPERATION. 


ZERO? 


DO RECAL IF ZERO 


TRK ADR TO D 
TEST FOR ILLEGAL TRACK 

ANTICIPATE WITH ERROR CODE 
RETURN IF ERROR 
TRK ADR TO ACC. 


TRK>43? | 


JUMP IF NOT 


SET LO CURR BIT 


SET HL = 


TRK REG 


TRK ADR TO ACC. 
COMPARE TARGET TRACK TO DESTINATION TRACK 


RETURN WHEN EQUAL 
DO A STEP OF HEAD 


LOOP 


LOAD UNIT SELECT 
JUMP TO DO STEP OUT 
ELSE STEP IN 
INCREMENT CURRENT TRACK 


FETCH TARGET TRACK ADDRESS 


DECREMENT CURRENT TRACK 


WRITE FDD CONTROL PORT 


; STEP=1 


WRITE FDD CONTROL PORT, STEP=0 


WRITE FDD CNT PORT, STEP=1 


WRITE FDD CONTROL PORT, DIR=1 
10 MS TIMING FOR STEP RATE 


DELAY LOOP 
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’ 
; ADDRESS CURRENT UNIT'S TRACK ADDRESS REGISTER, POINTER RETURNED 
: IN HL. 
9 ~ 
TRKREG: 
O2CA 210E40 LXI H, TRKRGO ; TRACK REGISTER, UNIT 0, INDEX BASE ADD, 
02CD 3A0D40 LDA UNIT ; FETCH REQUESTED UNIT NUMBER 
02D0 4F MOV C,A ; ADD TO INDEX 
02D1 0600 MVI B,0 a 
02D3 09 DAD B ; INDEX # ADDED TO BASE= TARGET TRK CURRENT REG 
O2D4 C9 RET 
; FHEKKHKKLLTLETKLTFCLEKTETELTTLTKLKKCLKTEKEKTEKTKKTETERTKKKAKETEKLE RELA KE 
’ 
es. RECALIBRATE HEAD TO TRACK 0. THE FDD IS STEPPED UNTIL 
. THE TRK 0 SIGNAL GOES TRUE FROM THE FDD I/F. 
’ 
RECAL: ; RECALIBRATE COMMAND 
02D5 CDCA02 CALL TRKREG ; SET HL=TRK REG 
L2D0: > 
02D8 3600 MVI M,0 ; ZERO TRK REG 
O2DA DB66 IN RDSTAT ; READ FDD STATUS PORT 
O2DC E640 | ANI 40H ; ISOLATE TRK 0 SIGNAL FROM FDD 
O2DE C8 RZ ; RETURN WHEN TRK=0 
O2DF 37 STC ; SET FLAG FOR STEP 
O2EO CDA202 CALL STEP ; DO A STEP 
02E3 C3D802 JMP L2D0 


EKFCKKTKTFTEKLAKEKLTKKHKKKLTKKKKKHKKLRKAKKLKTKKKKEKKLKRKKKTKKKKKHKKHRKKEREE 


WRENBL- SET WRITE ENABLE CONTROL TO FDD, LOAD HEAD, TEST = 
WRITE PROTECT SIGNAL FROM FDD. IF PROTECTED RETURN ZERO 
FLAG IN ACC SET. 


EZ we we we BS we we 


RENBL: 
O2E6 3A1240 LDA DDSDFL 
O2E9 2F CMA 
O2EA E601 ANI 1 ; ISOLATE SD/DD BIT 
O2EC F606 ORI 6 ; SET WRENA & HEAD LOAD BITS 
O2EE D367 OUT WRCNT1 3; WRITE CONTROL PORT ~ 
O2F0O DB66 IN RDSTAT ; READ FDD STATUS PORT 
O2F2 E620 ANI 20H ; ISOLATE WRITE PROTECT LINE 
O2F4 3E20 MVI A,20H 
02F6 C9 RET ; RETURN WITH FLAGS SET 


READ, WRITE, WRITDL- SET RWFLG, SEEK THE TRACK, TEST SECTOR 
ADDRESSING AND RECORD COUNT. RETURN WITH ADDRESS ERROR IF 
SCTADR BAD OR COUNT (NUMRCD) TOO LARGE (MULTI-TRACK). 


SI we we we We we wo 


EAD: 
O2F7 AF XRA A ; READ, VERIFY CRC COMMAND 
02F8 C30803 JMP L300 
WRITDL: 
O2FB 211640 LXI H,4016H ; FIX FLAG, WRITE DELETED COMMAND 
O2FE 7E MOV A,M ey 


O2FF E6F8 ANI NOT 7 
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0301 77 MOV MA 
WRITE: 
0302 CDE602 CALL WRENBL ; WRITE COMMAND, CALL WR ENABLE 
0305 C8 RZ ; RETURN ERROR IF WRITE PROTECTED 
0306 3EFF MVI A,OFFH ; SET FLAG 
L300: 
0308 321540 STA RWFLG ; READ WRITE FLAG ; STORE FLAG 
030B CD7C02 CALL SEEK ; FIX CNTL, DO SEEK 
030E B7 ORA A 
- O030F CO RNZ ; RETURN IF SEEK ERROR 
0310 210440 LXI H,SCTADR ; POINT TO SECTOR ADDRESS 
0313 0636 MVI B, 36H ; DD EOT SECTOR +1 
0315 3A1240 LDA DDSDFL ; TEST FOR DD 
0318 B7 ORA A 
0319 TE MOV A,M ; FETCH SECTOR ADDRESS 
031A C22203 JNZ L31A ; JUMP IF DD 
031D E61F ANI 1FH ; ISOLATE LEGAL SD SECTOR ADDRESSES 
O31F 77 MOV M,A ; RESTORE CORRECTED ADDR 
0320 061C MVI B,1CH ; MAX SD ADDR +1 
L31A: 
0322 3C INR A 
0323 321940 STA FLAGD ; STORE NEXT SECTOR ADDRESS 
0326 3D DCR A ; TEST FOR ZERO 
0327 3E08 MVI A,8 ; ANTICIPATE ADDRESS ERROR 
0329 C8 RZ ; RETURN IF SECTOR ADDR=0, ILLEGAL 
032A 110240 LXI D, NUMRCD ; FETCH # RECORDS 
032D 1A LDAX D 
032E 86 ADD M ; ADD ADDRESS TO # OF RECORDS 
032F B8 CMP B ; TOO MUCH? 
0330 3E08 MVI A,8 ; ANTICIPATE ERROR 
0332 DO RNC ; RETURN ERROR IF TOO MUCH 
0333 1A LDAX D ; LOAD AGAIN # RECORDS 
0334 BT ORA A 
0335 1F RAR 
0336 321840 STA FLAGC 
0339 CEOO ACI 0 
033B 12 STAX D 
L334: 
033C AF XRA A 
033D 321740 STA FLAGB 
0340 2A0540 »  LHLD BUFFER ; LOAD BUFFER ADDR 
0343 017F80 LXI B,807FH ; DMA CYCLE, TC 
0346 3A1540 LDA RWFLG ; READ WRITE FLAG, FLAG =0 FOR READ, NZ FOR WRITE 
0349 BT ORA A 
O34A CHF901 CNZ DMALOD ; DMA LOAD UP 
034D 3E04 MVI A,4 ; COUNT FOUR DISK REVS 
O34F 321340 STA INDXCT ; INDEX COUNT 
L34A: 
0352 210065 LXI H,6500H 
0355 110062 LXI D, DISKIO 
0358 3A1240 LDA DDSDFL 
035B B7 ORA A 
035C CAATO4 JZ L49B 
L357: 


035F 3600 MVI M,0 ; WRCLK 
0361 DB66 IN RDSTAT ; READ FDD STATUS PORT 
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0363 
0366 
0367 


036A 
036B 
036E 
0371 
0372 
0375 


0377 
0378 
0379 
037C 
037D 
0380 
0382 
0383 
0386 
0388 


038B 
038C 
038F 
0390 
0393 
0394 
0395 
0396 
0397 
039A 
039B 
039C 
039D 
039E 
03A0 
03A1 
03A4 
03A5 
03A6 
O3A7 
03A8 
03AB 
O3AC 
O3AF 
03B0 
03B3 
03B4 
03B7 


03B9 


FA6604 


04 
CA6 303 
340063 


C25F03 


3A1240 
BT 
CADFO4 
1A 
341540 
B7 
C20104 
0612 


1A 


L35B: 


L362: 


L36F: 


Ct we wo we 


383: 


L3B1: 


I.D. 


ZX-200A 


INDXCT 
A 
L45F 


B 

L35B 
SYNCPL 
A 

L362 
C,06 


RECORD 


we 


we we we 


we we we we we we we WO we WE 


FLOPPY CONTROLLER V1.2 


INDEX COUNT 


SYNCHPLO 


DISKRD 


DISKRD 
RDMRKA 
I.D. ADDRESS MARK? 
NO, JUMP, TRY AGAIN 


; READ TRACK I.D. 


; COMPARE TRK 


DISKRD, DISCARD SIDE I.D. 
COMPARE SECTOR ADDR 
DISK READ, SECTOR I.D. 


READ SECTOR LENGHT CODE 
READ CRC BYTES 


READ FDD STATUS PORT 
CRCSTAT? 

JUMP CRC ERROR 
DISKRD 

INX SECTOR ADR 


DISKRD 
TEST SD/DD MODE 


JUMP IF SD 
DISKRD 
READ WRITE FLAG TEST 


JUMP IF WRITE 


DISKRD 
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03BA 
03BB 
03BE 
O3BF 


03C2 : 


03C4 


03C5 
03C8 
03C9 
03CC 
03CE 
03CF 
03D2 
03D4 


03D7 
O3DA 
03DC 
03DD 
03DE 


03E0 
03E1 
03E2 
03E3 
03E4 
03E7 
03E8 
03E9 
O3EA 
03EC 
03ED 
O3EF 
03F0 
03F3 
03F6 
03F9 
03FB 
03FE 


0401 
0402 


0404 
0405 
0406 
0409 
O40A 


C29004 


2A0540 
2643 
1A 

TT 
OE7F 


2c 
1A 
TT 
OD 
C2E003 


L3BC: 


L3BD: 


Cot we we we 


3CF: 


L3D9: 


[ot we we wo 
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B 
L3B1 

D 

H,6500H 

M,0 ; MAKE SYNCHMARK=0 

SYNCPL ; SYNCPLO 

A 

L3BC 

M,70H ; SYNCHMARK=70H 

D 

MARK =; READ DATA ADDDRESS MARK 
OBH ; GOOD? 

L489; JUMP IF BAD 


READ DISK RECORD INTO 2114 BUFFER 


BUFFER ; LOAD BUFFER ADDRESS 
H,43H 
D ; READ BYTE ONE 
M,A ; STORE IN 2114 
C,7FH  ; SET UP LOOP FOR 127 MORE 
L ; ADJUST 2114 POINTER 
D ; READ DISK BYTE 
M,A ; STORE IN 2114 
c 
L3D9 
D ; READ CRC BYTES 
D 
D ; GAP 3 READ 
RDSTAT ; READ FDD STATUS PORT 

; CRCSTAT? 
A,2 ; ANTICIPATE CRC ERROR 

; RETURN IF ERROR 
BUFFER ; LOAD BUFFER ADDR 
B,407FH ; READ CYCLE, TC, FOR READ COMMAND TO DMAC 
DKINST ; FETCH OPCODE 
1 ; SEE IF DATA TRANSFER TYPE 
DMALOD ; LOAD DMAC CHIP 
L432 
DISK RECORD, SPLICE GAP 2 
D ; READ GAP 2 BYTE 
C,9 
D READ GAP 2 


; DECREMENT LOOP 
LOOP TEN TIMES 
SPLICE IN SAME BYTE READ 


c. 
Ww 
i? | 
ie] 
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O40B 
O40D 


O40F 
0410 
0411 
0414 


0417 
0418 
O41B 
O41D 
O41E 
0421 
0422 
0423 
0424 


0426 
0427 
0428 
0429 
O42A 
O42D 
0430 
0433 
0434 
0437 
0438 
0439 
O43ZA 


043B 
043E 
O43F 
0442 
0443 
O4NG 
0449 
O44A 
O44B 
O4AC 
O4AD 
O4E 
O44F 
0452 
0455 
0456 
0457 
0458 
0459 
O45A 
O45C 


3EFF 
OE08 


12 
OD 
C20F04 
010061 


i 
2A0540 
2643 
12 
3A1640 
02 

TE 

12 
OE7F 


2c 
TE 
12 
OD 
C22604 
320063 
3A1240 


210240 
35 
C23C03 
111840 
1A 
BT 
C8 
TT 
AF 
12 
341940 
210440 


1E80 
240540 


L409: 


[rt we we we 


411: 


L421: 


L432: 


#014 


MVI 
MVI 


STAX 
DCR 
JNZ 
LXI 
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L409 
B, MARK 


NOW WRITE FF SYNC IN 


SPLICE 


WRITE 9 BYTES OF FF 


POINT TO WRMRK 


WRITE DISK FROM 2114 BUFFER 


STAX 
LHLD 
MVI 
STAX 
LDA 
STAX 
MOV 
STAX 
MVI 


INR 
MOV 
STAX 
DCR 


wmo wo Bi <i ws oe 


qg<=-= « 


lw Bw] 


9 


Ome 
WwW 
= 


= + 


LAGD 


we we 


we we we we we We we 


we we 


ow 
= 
g rey 
Ss 8 
+ 
—_— 


ONE MORE SPLICE BYTE 
LOAD BUFFER ADDRESS 


LAST SPLICE BYTE 
DATA ADDRESS MARK 


WRMRK 


READ BUFFER 

WRITE FIRST DATA BYTE 

LOOP COUNT ONE SECTOR 

WRITE REMAINING 127 FROM LOOP 


READ BUFFER 
WRITE DATA TO DISK 


WRITE TWO CRC BYTES 


WRCRC (WRITE CRC BYTE) 
SPLICE GAP 3 


UO rt 


INX BUFFER ADDR ONE 


BUFFER MSD 
ADVANCE BUFFER ADDRESS BY ONE BLOCK 


DCR # RECORDS 


ETCH SECTOR ADDR 
EPLACE IT 


SECTOR COUNT 
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O45F 19 
0460 220540 
0463 C33C03 
L45F: 
0466 3A1740 
0469 BT 
O46A CO 
O46B 3E0E 
O46D C9 
L467: 
O46E 1A 
O46F 1A 
O470 1A 
O471 1A 
O472 1A 
0473 1A 
L46D: 
O474 DB66 
O476 17 
0477 DA8804 
O47TA 3E04 
O47TC 321740 
O4TF CDD502 
0482 CD7CO2 
0485 C35203 
L481: 
0488 3E0A 
O48A 321740 
O48D C35203 
L489: 
0490 FEO8 
0492 C39704 
LYU8E: 
0495 FEF8 
L4A2: 
0497 3EOF 
L492: 
0499 321740 
O49C 3E01 
O4SE C8 
OX9OF 210440 
OH4A2 35 
O4A3 35 
O4A4 C35203 
: L49B: 
O4AT 36FF 
L49D: 
O4A9 3A1340 
O4AC BT 
O4AD FA6604 
L4AY: 
O4BO 04 
O4B1 CAA904 
O4B4 3A0063 
O4BT7 B7 
O4B8 C2B004 
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D 
BUFFER 
L334 


FLAGB 
A 


A, OEH 


INDXCT 
A 
L45F 


B 

L49D 
SYNCPL 
A 

L4A4 


> SIXTH TIME 


; CRCSTAT? 
; JUMP CRC ERROR 


; SINGLE DENSITY WRITE 
; INDEX COUNT 
; INX LOOP COUNT 


; SYNCPLO 


; LOOP TILL 00 READ 
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O4BB 
O4BC 
O4BD 
04CO 
O4C1 
O4C2 


04C5 


O4CT7 
O4CA 
O4CB 
O4CE 
O4DO 
04D3 
O4DS5 
0O4D8 
O4D9 
O4DC 


O4DF 
O4E2 
- O4E3 
O46 
O4ET 


O4EQ 
O4FA 
O4EB 
O4EE 
OEF 
O4F2 
O4FY 
OFT 
O4FO 
O4FC 
O4FE 
0501 


0504 
0505 
0506 
0508 
0509 
O50A 
050B 
050C 
050D 
O50E 
O50F 
0510 
0513 


1A 
BT 
C2B004 
1A 
B7 
C2B004 


36C7 


340060 


3A1540 
B7 
C20405 
1A 
060A 


LHAF: 


L4B9: 


L4BB: — 


L4D3: 


L4DD: 


L4F8: 


we we 


JMP 


 ZX-200A 


8 
3 
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we 


we we we 


we we 


we 


READ GAP TILL 00 READ 


WRITE C7 SYNCH MARK 
READ DATA MARK 
LOOP TILL NON-ZERO 


SEE IF CORRECT DATA MARK 
JUMP IF GOOD 


READ WRITE FLAG 


WAS 7, READ IN THREE EXTRA TO IGNORE 
THANKS TO LARRY BOBERG. | 


WRCLK 


KKKEKFKKKKTEKKTEKKKLTTKFKEKTFKTKLKKKCKKKTKLTKEKKKKKKKKTKKEKKKKKKKKEKKKKKKKRRKKKARS .. 


CP/M MACRO 


0516 
0519 
O51A 
051B 
O51E 
O51F 
0522 
0525 
0528 
052A 
052D 
052F 
0532 
0533 
0534 


0537 
0538 
0539 
053A 
053B 
053C 
053D 
0540 


0541 
O544 
0547 
0549 
O54A 
O54D 
O54E 
0551 
0552 
0553 
0556 
0557 


0559 
055A 
055B 


CD7C02 
B7 
CO 
CDE602 
c8 
016880 
2A0540 


010134 


71 
2C 
TT 
2c 
oc 
05 
C23705 
E1 


011340 
110062 


12 


C25905 


ASSEM 2.0 


e 
b 
° 
9 
e 
? 
° 
? 
e 
? 
° 
9 
° 
? 
° 
? 
e 
? 


ORMAT: 


L52B: 


[rt we we we wo 


535: 


L545: 


L54D: 
DDGAP 1: 


#017 
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FORMAT A TRACK- THIS COMMAND WILL SEEK THE TRACK, READ IN 
USER BUFFER, AND EITHER WRITE SEQUENTIAL OR RANDOM NUMBERED 
SECTORS FILLED WITH USER DATA FILLER BYTE. FOR SEQUENTIAL 
SECTORS ONLY THE FIRST BYTE OF USER BUFFER SPECIFIES WHAT 
ALL SECTORS ON THE TRACK WILL HAVE THEIR DATA FIELDS FILLED 
WITH. FORMAT WRITES ALL MARKS, GAPS, AND FIELDS ACCORDING 
TO FM FORMAT OR MMFM FORMAT. MMFM/FM TYPE IS SIGNALLED BY 


FLAG 


"DDSDFL" . 


SEEK 
A 


WRENBL 
B, 8068H 


BUFFER 
DMALOD 


RANDOM FORMAT. 
FILLER BYTE IS COMPLETE. 


B, INDXCT 
D,DISKIO 


A,1 

B 
DDSDFL 
A 

L5B1 

B 

A 

L545 

A 
C,3FH 


L54D 


FORMAT COMMAND, DO SEEK 


RETURN IF ERRORS 

CALL WRITE ENABLE 

RETURN IF ERROR 

DMA CYCLE, TC BYTES 

READ FORMAT TABLE FROM HOST AT BUFFER 
ARM DMA 

POINT TO PAGE IN 2114 

FETCH CHANNEL WORD 

RANDOM FORMAT? 

JUMP IF RANDOM 

ELSE DO SEQUENTIAL SECTORS 
FILL ALL SECTORS WITH THIS DATA 
LOOP COUNT =34H, SECTOR # 1 


WRITE SECTOR NUMBER 


WRITE DATA BYTE 


AT THIS POINT THE TABLE OF SECTOR ORDER AND 


INDEX COUNT 

POINTER FOR STAX D TO WRITE DISK 
INDEX 1 DISK REV. 

STORE IN FLAG 

TEST DD OR SD FORMAT 


~we we 


JUMP IF SD 
FETCH INDEX COUNTER 


LOOP TILL INDEX MARK 


WRITE GAP 1, 64 ZERO'S 
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055E 
O55F 


0561 
0563 
0565 


0567 
0568 
0569 
056C 
056D 
056F 
0572 
0575 
0576 
O577 
0578 
0579 
O57A 
057B 
O57C 
057D 
0580 
0583 


0585 
0586 
0587 
058A 
058B 


O58D | 


O58F 
0590 
0591 
0594 
0595 
0597 
059A 
059B 


059D 
059E 
059F 
05A2 
05A3 
O5A4 
O5AT7 
05A8 
05AB 


O5AD 
O5AE 


12 


0634 


3E0B 
320061 
TE 
OE7F 


12 

OD 
C29D05 
12 

AF 
320063 
2c 
320063 
OE11 


12 
OD 


L555: 


L55B: 


DDGAP2: 
L57TA: 


L584: 


L593: 


DDGAP3: 
L5A3: 


ZX-200A 


D 
B, 34H 


RDSTAT 
A, OFFH 
C,9 


FLOPPY CONTROLLER V1.2 


we we we we We we WO we We we WO we w2e we 


we we we We we 


ONE MORE 
DD SECTOR COUNT 


WRITE OFFH TEN TIMES 


LOOP 


ONE MORE 
WRITE I.D. 


WRMRK 


LOAD TRACK ADDR 


WRDISK 
ACC=0 
WRDISK 


FETCH SECTOR I.D. 


WRDISK 
ACC=0 


WRDISK 
WRCRC 
WRCRC 


WRITE 11 ZERO'S 


ONE MORE 
WRITE NINE OFFH'S 


WRDISK 


ONE MORE 

WRITE DATA MARK 

SEND TO DISK 

LOAD DATA BYTE FOR FILL 
ONE SECTOR COUNT-1 


FILL DATA FIELD . 


ONE MORE 


ADDRESS MARK 


FOR MMFM 


WRITE TWO DATA FIELD CRC BYTES 


WRCRC 


~ CP/M MACRO ASSEM 2.0 


O5AF 

— D582 
05B3 
—.05B4 
J5B7 

05B8 


ey O5BC 


C2AD05 


C31E06 


OA 
BT 
C2BB05 
3EFF 
OE48 


Crt we wo wo 


Ui 
ies) 
— 


ewe we 


9 
L5BA: 
SDGAP1: 


L5C2: 


L5E4: 


#019 


JNZ 
STAX 
DCR 
JNZ 
STAX 
JMP 
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L5A3 
D 


B 


L555 
D 
L6 16 


e 
9 
° 
? 


e 
? 
e 
? 
e 
9 


WRITE 


17 ZERO'S 


ONE MORE 


DO NEXT RECORD 


WRITE 


A ZERO 


DO GAP 4 AND RETURN 


WAIT FOR INDEX MARK 


LDAX 
ORA 
JNZ 
MVI 
MVI 


STAX 
DCR 
JNZ 
STAX 
MVI 


XRA 
STAX 
STAX 
STAX 
STAX 
STAX 
STAX 
MVI 
STA 
LDA 
STAX 
XRA 
STAX 
MOV 
STAX 
XRA 
INR 
STAX 
MVI 
STA 
STA 


B 

A 

L5B1 
A, OFFH 
C,48H 


? 


we we we 


? 


TEST INDEX FLAG 


LOOP TILL INDEX 


WRITE 


_ SINGLE DENSITY FORMAT RECORD 


48H OFFH'S 


ONE MORE 
26 SECTORS LOOP COUNT 


WRITE 


WRITE 


FETCH 
WRITE 


WRITE 
FETCH 
WRITE 
WRITE 


WRITE 
WRCRC 


WRITE 


6 ZERO'S 


I.D. RECORD MARK 


TRACK ADDRESS 
TRACK I.D. 


SIDE 0 I.D. 

SECTOR ADDRESS 
SECTOR I.D. 

SECTOR LENGHT CODE=0 


TWO CRC BYTES 


FF 


ONE MORE FF 


CP/M MACRO ASSEM 2.0 #020 . ZX-200A FLOPPY CONTROLLER V1.2 


O5F3 AF XRA A 

O5F4 12 STAX D ; WRITE ZERO'S 

O5F5 12 STAX D | . 
O5F6 12 STAX D 

O5F7 12 STAX D 

O5F8 12 STAX D 

O5F9 12 STAX D 


WRITE DATA FIELD 


we we we 


O5FA 3EFB MVI A,OFBH ; WRITE DATA ADDRESS MARK 
O5FC 320060 STA MRKCRC ; WRMRKCRC 
O5FF 7E MOV A,M ; FETCH FILLER DATA 
0600 OE7F MVI C,7FH 
L5FA: 
0602 12 STAX D ; FILL ANOTHER 127 BYTES WITH SAME DATA 
0603 OD DCR C 
0604 C20206 JNZ L5FA 
0607 12 STAX D 
0608 3EFF MVI A,OFFH ; WRITE TWO CRC BYTES 
060A 320063 STA WRCRC 
060D 2C INR Ls 
060E 320063 STA WRCRC 
0611 OE1A MVI C,1AH ; WRITE GAP 3 
L60B: 
SDGAP3: 
0613 12 STAX D ; FILL WITH FF 
0614 OD DCR C 
0615 C21306 JINZ L60B 
0618 12 STAX D ; ONE MORE FF 
0619 05 DCR B 
061A C2CCO5 JINZ L5C2 
061D 12 STAX D 
GAP4: 
L616: 
061E EB XCHG 
061F 111340 LXI D, INDXCT ; INDEX COUNT 
0622 47 MOV B,A 
L61B: ; WRITE GAP 4 TILL INDEX MARK 
0623 70 MOV M,B 
0624 1A LDAX D ; FETCH INDEX COUNT 
0625 B7 ORA A 
0626 F22306 JP L61B 
0629 AF XRA A 
062A C9 RET ; RETURN TO MAINLINE 


we WO we we 


RAM BUFFER 
4000 ORG 4000H 
IOPB: 
4000 CHANWD: DS 1 ; IOPB CHANNEL WORD 
4001 DKINST: DS 1 ; DISK INSTRUCTION 
4002 | NUMRCD: DS 1 ; NUMBER OF RECORDS 
1 ; 


4003 TRKADR: DS TRACK ADDRESS 


CP/M MACRO ASSEM 2.0 


4004 
4005 
4007 


~ 4008 


400A 
400D 


400D 
400E 
‘4012 
4013 
4014 
4015 
4016 
4017 
4018 
4019 


HO1A 


SCTADR: 
BUFFER: 
BLOCKN: 
NXIOPB: 
UNITSL: 


UNIT: 

TRKRGO: 
DDSDFL: 
INDXCT: 
RDYBIT: 
RWFLG: 
DAMARK : 
FLAGB: 
FLAGC: 
FLAGD: 


END 


ZX=200A FLOPPY CONTROLLER V1.2 


Fea =h = 


OODH 


ee ee ee ee ee ee | 


ZX202 


we we we we we 


SECTOR ADDRESS 

BUFFER ADDRESS 

BLOCK NUMBER, SD LINKED ONLY 
NEXT IOPB ADDRESS, LINKED 
ADDR=400AH 


UNIT TRACK REGISTER ARRAY 
SINGLE/DOUBLE DENSITY FLAG 
INDEX COUNTER 

READY BIT STATUS FROM FDD 
READ/WRITE FLAG 

DATA ADDRESS MARK 


4007 
4016 

O2BF 
2008 
4019 
4000 
0139 
01F0 
023B 
0257 

026A 
0308 
0363 
03C4 

0401 

043B 
0490 
OO4A 
O4CT 
0541 

0567 
O5BB 
0613 
009C 
6100 
6403 
0067 
02D5, 
05C4 
6300 
400D 
0066 
0000 


BLOCKN 
DAMARK 
DELAY 
DMAMOD 
FLAGD 
IOPB 
L13A 
L1E6 
L23A 
L256 
L269 
L300 
L35B 
L3BC 
L3FB 
L432 
L489 
L4A 
L4BB 
L535 
L55B 
L5B1 
L60B 
LOB 
MARK 
PORT7B 
RDRDY 
RECAL 
SDGAP1 
SYNCPL 
UNIT 
WRCONT 
ZX202 


4005 
0559 
6200 
2001 
0516 
00D9 
0152 
020D 
0241 
025C 
026C 
0322 
036A 
03C5 
0404 
0466 
0495 
0497 
O4DF 
0054 
0585 
05C4 
061E 
00CO 
6000 
6400 
0066 
4015 
0613 
O2BD 
01DB 
6300 


BUFFER 
DDGAP 1 
DISKIO 
DMATC 


FORMAT . 


LODA 
L153 
L20C 
L240 
L25B 
L26B 
L31A 
L362 
L3BD 
L3FE 
L45F 
L48E 
L4A2 
L4D3 
L54 
L57A 
L5BA 
L616 
LCO 
MRKCRC 
PORT89 
RDSTAT 
RWFLG 
SDGAP3 
TENMS 
UNITAB 
WRCRC 


4000 
0585 
4001 


0015 


061E 
0107 
0161 
0224 
0247 
025E 
O2AC 
033C 
0377 
003C 
O40F 


—O46E 


0499 
O4BO 
O4EI 
0551 
058F 
O05CC 
0623 
00C1 
4002 
6401 
4014 
0296 
027C 
4003 
400A 
02E6 


CHANWD 
DDGAP2 
DKINST 
DSKCLR 
GAP4 
L108 
L162 
L223 
L246 
L25D 
L2AB 


L334. 


L36F 
L3C 
L409 


L467 | 


L492 
L4A4 
L4DD 
L545 
L584 
L5C2 
L6 1B 


TRKADR 
UNITSL 
WRENBL 


0080 
O5AD 
2000 
4017 
0020 
011D 
0184 
0234 
O24A 
0263 
02C1 
0352 
038B 
03D7 
0417 
O474 
O4AT 
04BB 
0504 


_ 0559 


059D 
O5ED 
006A 
0028 
4008 
0009 
0074 
0299 
02A2 
02CA 
6500 
O2FB 


CLRINT 
DDGAP3 
DMADDR 
FLAGB 
INDEX 
L11E 
L185 
L233 
L249 
L262 
L2B9 
L34A 
L383 
L3CF 
L411 
L46D 
L49B 
LU AF 
L4F8 
L54D 
L593 
L5Ey 
L6A 
MA78 
NXIOPB 
RAMCLR 
RDYINT 
S2 
STEP 
TRKREG 
WRCLK 
WRITDL 


01CB 
4012 
01F9 
4018 
4013 
0121 
01E3 
0237 
0253 
0268 
02D8 
035F 
03B9 
03E0 
0426 
0488 
O4A9 
04C5 
0537 
0561 
O5AD 
0602 
0096 
0034 
6402 
6500 
02F7 
4004 
003C 
400E 
0067 
0302 


CTAB 
DDSDFL 
DMALOD 
FLAGC 
INDXCT 
L122 
L1D7 
L236 
L252 
L267 
L2D0 
L357 
L3B1 
L3D9 
L421 
L481 
L49D 
L4B9 
L52B 
L555 
L5A3 
L5FA 
L95 
MA88 
PORT79 
RDPRT1 
READ 
SCTADR 
STOP 
TRKRGO 
WRCNT1 
WRITE 


Bill of Materials 


Item # Qty. Part # Description 

R8, 9 2 10KOHM Resistor 

R2 1 1500HM Resistor 

RO. 7 2 1KOHM Resistor 

R11, 12 2 2.2 KOHM Resistor 

U47, 48 2 2114-3 re Ce 

U6 3 1 2716-ZX200 I.C. EPROM Version 1.1 
for ZX-200 

Rl 1 3300HM Resistor 

R113, 14 2 4308R-101-471 Bourns 8P SIP 

R3, 4, 10 3 4700HM Resistor 

XU43 1 516-AG11D Dip Socket 

XU20-22 3 520-AG11D Dip Socket 

XU63 1 524-AG11D Dip Socket 

W3 1 530153-1 Jumper 

XU64, 65 2 540-AG11D ~ Dip Socket 

Ull, 36, 41, 

45, 52, 82, 

84 7 74LS00 I.C., LS TTL 

US1 1 74LS02 I.C., LS TTL 

U9, 18, 42 3 74LS04 ICs, LS TTL 

U12 1 74LS08 I.C., LS TTL 

U24, 35, 61 3 74LS0 I.Gs, LS TTL 

U6, 59 2 74LS113 1.C., LS TTL 

U70 1 74LS13 I.C., LS TTL 

U53, 54, 55 3 74LS14 I.C., LS TTL 

U25 1 74LS155 I.C., LS TTL 

U39 1 74LS157 I.C., LS TTL 

u40 1 74LS163 I.C., LS TTL 

U15, 16 2 74LS165 I.C., LS TTL 

U4, 17, 31, 

38, 83 5 74LS174 I.C., LS TTL 

U3 0 1 74LS244 I.C., LS TTL 

U33, 34 2 74LS266 I.C., LS TTL 

U32 1 74LS273 I.C., LS TTL 

U27 1 74LS279 i.C., LS TEL 

U23 1 74LS32 I.C., LS TTL 

U10, 69 2 74LS367 I.C., LS TTL 

U49 1 74LS373 I.C., LS TIL 

U14 1 74LS374 I.C., LS TTL 

U8, 13 2 74LS38 I.C., LS TTL 

U76-81 6 74LS670 I.C., LS TTL 

U5, 19, 50 3 74LS74 T.C.; LS TTL 

U68 1 74S00 I.C. TTL SCHOTTKY 

Ul, 60 2 74804 T,C, 

U57 1 74S10 I.C. TTL SCHOTTKY 

U2, 3 2 748163 I.C. TTL SCHOTTKY 

U20, 21 2 748471 TI TBP18S22 Bipolar PROM 

U58, 71 2 74S74 TGs 
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Bill of Materials (continued) 


Item # Qty 


U65 
U64 
XW3 
U43 
U6 6 2. 


Hoe 


j_ 
°o 
1 
_ 
NN) 
> 
ee a ee 


Part # 


8085A-2 
8257-5 
B7022-A 
93446PC 
9401 


AM2946 
AM2956 . 
AM2957 
C40C100K 


C41C104K 
CD40 40BE 
CY22A 
CY6C 
TE-1211 
PCZX-200A 
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Description 


I.C., 8-Bit CPU 

DMA CHIP 

AMP Wire Wrap Post 

I.C., BIPOLAR PROM 

IC CRC Generator 
& Checker 


LsGs 
d<Ce 
EsGy 
Centralab Cap 


Centralab Cap 

I.C. CMOS 

Crystek 20 MHz Crystal 
Xtal 6.144 MHz 

Sprague Cap 

PC Board, ZX-200A 
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